gulp任务

项目使用的gulp自动化任务

//定义输出文件夹名称
var distFolderH5 = "distH5";
var distFolderMofang = "distMofang";

//定义根目录路径
var baseUrl = "../";
//定义html目录路径
var tplUrl = "../tpl/";
//定义js目录路径
var jsUrl = "../js/";
//定义css目录路径
var cssUrl = "../css/";
//定义sass目录路径
var sassUrl = "../sass/";
//定义less目录路径
var lessUrl = "../less/";
//定义font目录路径
var fontUrl = "../fonts/";
//定义img目录路径
var imgUrl = "../img/";
//定义媒体目录路径
var mediaUrl = "../media/";
//定义第三方库目录路径
var libUrl = "../lib/";
//定义版本号文件输出根目录
var revDist = "../rev/";
//定义html版本号输出目录路径
var revTplUrl = "../rev/tpl/";
//定义js版本号输出目录路径
var revJsUrl = "../rev/js/";
//定义css版本号输出目录路径
var revCssUrl = "../rev/css/";
//定义font版本号输出目录路径
var revFontUrl = "../rev/fonts/";
//定义img版本号输出目录路径
var revImgUrl = "../rev/img/";
//定义媒体文件版本号输出目录路径
var revMediaUrl = "../rev/media/";
//定义第三方库版本号输出目录路径
var revLibUrl = "../rev/lib/";

setDistFolder(distFolderH5);

function setDistFolder(distFolder){
    //定义输出目录名称
    distName = distFolder;
    //定义输出根目录
    dist = "../"+distFolder+"/";
    //定义html输出目录路径
    distTplUrl = "../"+distFolder+"/tpl/";
    //定义js输出目录路径
    distJsUrl = "../"+distFolder+"/js/";
    //定义css输出目录路径
    distCssUrl = "../"+distFolder+"/css/";
    //定义font输出目录路径
    distFontUrl = "../"+distFolder+"/fonts/";
    //定义img输出目录路径
    distImgUrl = "../"+distFolder+"/img/";
    //定义媒体输出目录路径
    distMediaUrl = "../"+distFolder+"/media/";
    //定义第三方库输出目录路径
    distLibUrl = "../"+distFolder+"/lib/";
}

var gulp = require('gulp'),
    //压缩html,可以压缩页面javascript、css,去除页面空格、注释,删除多余属性等操作
    html = require('gulp-htmlmin'),
    //sass编译
    sass = require('gulp-sass'),
    //对sass路径进行转换
    slash = require('slash'),
    //less编译
    less = require('gulp-less'),
    //css压缩
    minifycss = require('gulp-clean-css'),
    //js压缩
    uglify = require('gulp-uglify'),
    //文件合并
    concat = require('gulp-concat'),
    //文件重命名
    rename = require('gulp-rename'),
    //清空文件夹
    clean = require('gulp-clean'),
    //压缩图片文件(包括PNG、JPEG、GIF和SVG图片)
    imagemin = require('gulp-imagemin'),
    pngquant = require('imagemin-pngquant'),
    //对文件名加MD5后缀
    rev = require('gulp-rev'),
    //路径替换
    revCollector = require('gulp-rev-collector'),
    //上传ftp服务器
    ftp = require('gulp-ftp'),
    //上传sftp服务器
    sftp = require('gulp-sftp'),
    //控制task顺序
    gulpSequence = require('gulp-sequence');
    //创建服务器
    connect = require('gulp-connect');
    //任务提醒
    notify = require('gulp-notify');

//gulp-html参数配置
var htmlOptions = {
    //清除HTML注释
    removeComments: true,
    //压缩HTML
    //collapseWhitespace: true,
    //省略布尔属性的值 <input checked="true"/> ==> <input />
    collapseBooleanAttributes: true,
    //删除所有空格作属性值 <input id="" /> ==> <input />
    removeEmptyAttributes: true,
    //删除<script>的type="text/javascript"
    removeScriptTypeAttributes: true,
    //删除<style>和<link>的type="text/css"
    removeStyleLinkTypeAttributes: true,
    //压缩页面JS
    //minifyJS: true,
    //压缩页面CSS
    //minifyCSS: true
};

//tpl模板压缩
gulp.task('tpl',function(){
   gulp.src(baseUrl+'index.html')
    .pipe(html(htmlOptions))
    //.pipe(rev())
    .pipe(gulp.dest(dist))
    //.pipe(rev.manifest())
    //.pipe(gulp.dest(revDist))

   gulp.src(tplUrl+'**/*.html')
    .pipe(html(htmlOptions))
    .pipe(rev())
    .pipe(gulp.dest(distTplUrl))
    .pipe(rev.manifest())
    .pipe(gulp.dest(revTplUrl))
});

//css压缩添加版本号
gulp.task('cssMin', function() {
    return gulp.src(cssUrl+'*.css')
        .pipe(minifycss())
        .pipe(rev())
        .pipe(gulp.dest(distCssUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revCssUrl));
});

//css合并添加版本号
gulp.task('cssCon', function() {
    //需要处理的css文件,放到一个字符串数组里
    return gulp.src(cssUrl+'*.css')
        //合并后的文件名
        .pipe(concat('build.min.css'))
        //压缩处理成一行
        .pipe(minifycss())
        //文件名加MD5后缀
        .pipe(rev())
        //输出文件本地
        .pipe(gulp.dest(distCssUrl))
        //生成一个rev-manifest.json
        .pipe(rev.manifest())
        //将 rev-manifest.json 保存到 rev 目录内
        .pipe(gulp.dest(revCssUrl+'combine/'));
});

//复制未压缩的js添加版本号
gulp.task('jsNotMin', function () {
    return gulp.src([jsUrl+'config.js'])
        .pipe(rev())
        .pipe(gulp.dest(distJsUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revJsUrl+'notmin/'));
});

//js压缩添加版本号
gulp.task('jsMin', function () {
    return gulp.src([jsUrl+'*.js', "!"+jsUrl+'config.js'])
        //.pipe(uglify())
        .pipe(rev())
        .pipe(gulp.dest(distJsUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revJsUrl+'min/'));
});

//js合并添加版本号
gulp.task('jsCon', function () {
    return gulp.src([jsUrl+'*.js', "!"+jsUrl+'config.js', "!"+jsUrl+'shareMin.js'])
        .pipe(uglify())
        .pipe(concat('build.min.js'))
        .pipe(rev())
        .pipe(gulp.dest(distJsUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revJsUrl+'combine/'));
});

//图片压缩添加版本号
gulp.task('img',function() {
    return gulp.src(imgUrl+'**/*')
        .pipe(rev())
        .pipe(imagemin({progressive: true, svgoPlugins:[{removeViewBox:false}], use:[pngquant({quality: '70'})]}))
        .pipe(gulp.dest(distImgUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revImgUrl))
});

//sass编译
gulp.task('sass', function () {
    return gulp.src(sassUrl+'*.scss')
        .pipe(sass({outputStyle: 'compressed'}))
        .pipe(gulp.dest(cssUrl))
        //.pipe(connect.reload());
});

//less编译
gulp.task('less', function () {
    return gulp.src(lessUrl+'*.less')
        .pipe(less())
        .pipe(gulp.dest(cssUrl));
});

//添加版本号
gulp.task('revIndex', function () {
    return gulp.src([revDist+'**/*.json', dist+'index.html'])
        .pipe(revCollector({ replaceReved:true }))
        .pipe(gulp.dest(dist))
});
gulp.task('revTpl', function () {
    return gulp.src([revDist+'**/*.json', distTplUrl+'**/*.html'])
        .pipe(revCollector({ replaceReved:true }))
        .pipe(gulp.dest(distTplUrl))
});
gulp.task('revCss', function () {
    return gulp.src([revDist+'**/*.json', distCssUrl+'**/*.css'])
        .pipe(revCollector({ replaceReved:true }))
        .pipe(gulp.dest(distCssUrl))
});
gulp.task('revJs', function () {
    return gulp.src([revDist+'**/*.json', distJsUrl+'**/*.js'])
        .pipe(revCollector({ replaceReved:true }))
        .pipe(gulp.dest(distJsUrl))
});

//复制媒体文件和lib文件
gulp.task('copyFile', function () {
    gulp.src([mediaUrl+'**/*'])
        .pipe(rev())
        .pipe(gulp.dest(distMediaUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revMediaUrl));

    gulp.src([fontUrl+'**/*'])
        .pipe(rev())
        .pipe(gulp.dest(distFontUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revFontUrl));

    gulp.src([libUrl+'**/*'])
        .pipe(rev())
        .pipe(gulp.dest(distLibUrl))
        .pipe(rev.manifest())
        .pipe(gulp.dest(revLibUrl));
});

//清空输出目录并删除改目录
gulp.task('clean', function() {
    return gulp.src([baseUrl+distName, baseUrl+'/rev'], {read: false})
        .pipe(clean({force: true}));
});

//var ftpConfig = {
//    "localPath": {
//        "base": "../dist/"
//    },
//    "remotePath": {
//        "base": "dreamGame",
//        "project": "/var/disk/web/dev_local/app_web0/m.huanhuba.com/h5dev/dreamGame"
//    },
//    "project":{
//        "ftpTest": {
//            "use": true,
//            "host": "120.55.102.1",
//            "port":"220",
//            "user": "web",
//            "pass": "web123!@#"
//        }
//    }
//}
////上传ftp服务器
//gulp.task('ftp', function () {
//    return gulp.src(ftpConfig)
//            .pipe(sftp({
//                host: '120.55.102.1',
//                port: 220,
//                user: 'web',
//                pass: 'web123!@#'
//            }));
//})

//使用connect启动一个Web服务器
gulp.task('connect', function () {
  connect.server({
    //服务器根目录
    root: baseUrl,
    //访问IP
    ip: '127.1.1.1',
    //访问端口
    port: '8080',
    //是否启用热加载
    livereload: false
  });
});

// gulp.task('reload', function () {
//   gulp.src(tplUrl+'*.html')
//     .pipe(connect.reload());
// });

//打包任务
//[]中的是异步,运行完后运行rev
gulp.task("buildH5", function(cb){
    setDistFolder(distFolderH5);
    gulpSequence(['clean'], ['tpl'], ['copyFile', 'cssMin', 'cssCon', 'jsNotMin', 'jsMin', 'jsCon', 'img'], ['revIndex', 'revTpl', 'revCss', 'revJs'])(cb)
});

gulp.task("buildMofang", function(cb){
    setDistFolder(distFolderMofang);
    gulpSequence(['clean'], ['tpl'], ['copyFile', 'cssMin', 'cssCon', 'jsNotMin', 'jsMin', 'jsCon', 'img'], ['revIndex', 'revTpl', 'revCss', 'revJs'])(cb)
});

//监控
gulp.task('watch',function(){
    //gulp.watch(tplUrl+'*.html', ['html']);
    gulp.watch(sassUrl+'**/*.scss', ['sass']);
    //gulp.watch(cssUrl+'**/*.css', ['cssMin', 'cssCon']);
    //gulp.watch(jsUrl+'**/*.js', ['jsMin', 'jsCon']);
});
View Code

 package.json需要安装的一些模块

{
  "name": "projectName",
  "version": "1.0.0",
  "description": "projectDesc",
  "devDependencies": {
    "bower": "^1.7.7",
    "del": "^2.2.0",
    "gulp": "^3.9.1",
    "gulp-clean": "^0.3.2",
    "gulp-clean-css": "^2.0.7",
    "gulp-concat": "^2.6.0",
    "gulp-connect": "^4.1.0",
    "gulp-ftp": "^1.1.0",
    "gulp-htmlmin": "^2.0.0",
    "gulp-imagemin": "^3.0.1",
    "gulp-jshint": "^2.0.0",
    "gulp-less": "^3.1.0",
    "gulp-notify": "^2.2.0",
    "gulp-rename": "^1.2.2",
    "gulp-rev": "^7.0.0",
    "gulp-rev-collector": "^1.0.3",
    "gulp-ruby-sass": "^2.0.6",
    "gulp-sass": "^2.3.1",
    "gulp-sequence": "^0.4.5",
    "gulp-sftp": "^0.1.5",
    "gulp-uglify": "^1.5.3",
    "gulp-util": "^2.2.14",
    "imagemin": "^5.1.1",
    "imagemin-pngcrush": "^4.1.0",
    "imagemin-pngquant": "^5.0.0",
    "jshint": "^2.9.1",
    "shelljs": "^0.3.0",
    "slash": "^1.0.0"
  },
  "dependencies": {
    "textangular": "^1.5.4"
  }
}
View Code

gulp添加版本号还要改一些东西,如下

http://www.tuicool.com/articles/UbaqyyJ

原文地址:https://www.cnblogs.com/johnzhu/p/5992341.html