使用gulp搭建前端自动化开发环境

2017-07-26阅读(6065)评论(0)fishCat

苏州实时公交查询

现在写这个可能有点晚了,毕竟很早的东西了,我也一直在用,但是却没有完全自己动手重头开始搭建过,于是就实际操作了一番。

功能需求(基于nodejs):

1,html压缩,可配置
2,less编译,压缩
3,img压缩
4,ES6转ES5,压缩,纠错,可配置
5,打包发布
6,本地开发修改代码即时自动刷新

代码备注很详细,我就不一一说明了:

/*
 * @Author: fishCat
 * @Date:   2015-05-16 10:25:09
 * @Last Modified by:   oospace
 * @Last Modified time: 2017-05-16 16:27:54
 */
var gulp = require('gulp'); //  引入 gulp
var less = require('gulp-less');
var runSequence = require('run-sequence'); //让gulp任务,可以相互独立,解除任务间的依赖,增强task复用
var browserSync = require('browser-sync').create(); // browser-sync 实时刷新
var sourcemaps = require('gulp-sourcemaps'); // 源码压缩之后不易报错定位  sourcemaps用于错误查找

var jshint = require("gulp-jshint");//gulp jshint 插件主要用于检查代码,打印报告信息。
var stylish = require("jshint-stylish");

//当发生异常时提示错误 确保本地安装gulp-notify和gulp-plumber
var notify = require('gulp-notify');
var plumber = require('gulp-plumber');
var es2015 = require("babel-preset-es2015");
var minifycss = require('gulp-minify-css'); // 压缩css
var rpath = require("path");
var autoprefixer = require('gulp-autoprefixer'); // 处理浏览器私有前缀
var babel = require('gulp-babel'); // 编译ES6语法
var $ = require('gulp-load-plugins')();
var uglify = require('gulp-uglify'); // 压缩js

var concat = require('gulp-concat');//合并js
var htmlmin = require('gulp-htmlmin');

var fs = require('fs');
var del = require('del');
var promise = require('promise');
var imagemin = require('gulp-imagemin'); // 压缩图片
var contentIncluder = require('gulp-content-includer'); //通过includer导入方式导入不同的模块
var cache = require('gulp-cache'); //清除缓存
var rev = require('gulp-rev-append'); //添加MD5
var postcss = require('gulp-postcss'); //处理css
var cssnext = require('cssnext'); //使用CSS未来的语法
var precss = require('precss'); //编写Sass的函数

var postcss = require('gulp-postcss');
var autoprefixer = require('autoprefixer');

var developPath = "../src/";
var buildPath = "../dist/";
var clean = require('gulp-clean');
//获取文件夹下所有的文件名字并返回一个数组
var readFileNameList = function (path) {
    var result = [];

    function finder(path) {
        var files = fs.readdirSync(path);
        files.forEach(function (val, index) {
            var fPath = rpath.join(path, val);
            var stats = fs.statSync(fPath);
            if (stats.isDirectory()) finder(fPath);
            if (stats.isFile()) result.push(fPath.toString().split("\\").join("/"));
        });

    }

    finder(path);
    console.log(result);
    return result;
}

// 编译less,并压缩css输出到目标目录
gulp.task('css', function () {
    return gulp.src(developPath + "css/**")
        .pipe(sourcemaps.init())
        .pipe(plumber({errorHandler: notify.onError('Error: ')}))
        .pipe(postcss([autoprefixer({browsers: ['last 2 versions']})]))
        .pipe(less())
        .pipe(minifycss())
        .pipe(sourcemaps.write())
        .pipe(gulp.dest(buildPath + "css/"))
})

// 编译less,并压缩css输出到目标目录
gulp.task('css-dev', function () {
    return gulp.src(developPath + "css/**")
        .pipe(gulp.dest(buildPath + "css/"))
})

// 编译ES6到ES5,并压缩js 输出到目标目录
gulp.task('js', function () {
    return gulp.src((developPath + 'js/**'))
        .pipe(sourcemaps.init())
        .pipe(babel({
            presets: [es2015]
        }))
        .pipe(jshint(".jshintrc"))  /*Jshint可在package.json配置,也可在.jshintrc处配置。默认在单独文件中配置*/
        //.pipe(jshint.reporter("default"))
        .pipe(jshint.reporter(stylish))
        .pipe(uglify({mangle: false}))
        .pipe(sourcemaps.write())
        .on('error', function (e) {
            console.log(e);
        })
        .pipe(gulp.dest(buildPath + "js/"))
});

gulp.task('js-dev', function () {
    return gulp.src((developPath + 'js/**'))
        .pipe(gulp.dest(buildPath + "js/"))
});

// 拷贝 html
gulp.task('html', function () {
    var options = {
        removeComments: true,//清除HTML注释
        collapseWhitespace: true,//压缩HTML
        collapseBooleanAttributes: true,//省略布尔属性的值  ==> 
        removeEmptyAttributes: true,//删除所有空格作属性值  ==> 
        removeScriptTypeAttributes: true,//删除的type="text/javascript"
        removeStyleLinkTypeAttributes: true,//删除和的type="text/css"
        minifyJS: true,//压缩页面JS
        minifyCSS: true//压缩页面CSS
    };
    return gulp.src([developPath + '*.html'])
        .pipe(htmlmin(options))
        .pipe(gulp.dest(buildPath))
});

gulp.task('html-dev', function () {
    return gulp.src([developPath + '*.html'])
        .pipe(gulp.dest(buildPath))
});

// 图片压缩  输出到目标目录
gulp.task('images', function () {
    return gulp.src([developPath + 'imgs/*.*'])
        .pipe(imagemin())
        .pipe(gulp.dest(buildPath + "imgs/"))
});

// 图片压缩  输出到目标目录
gulp.task('images-dev', function () {
    return gulp.src([developPath + 'imgs/*.*'])
        .pipe(gulp.dest(buildPath + "imgs/"))
});

// 框架依赖  输出到目标目录
gulp.task('Edox', function () {
    return gulp.src([developPath + 'Edox/*.js'])
        .pipe(babel({
            presets: [es2015]
        }))
        .pipe(jshint(".jshintrc"))
        //.pipe(jshint.reporter("default"))
        .pipe(jshint.reporter(stylish))
        .pipe(uglify({mangle: false}))
        .pipe(gulp.dest(buildPath + "Edox/"))
});

// 框架依赖  输出到目标目录
gulp.task('Edox-dev', function () {
    return gulp.src([developPath + 'Edox/*.js'])
        .pipe(gulp.dest(buildPath + "Edox/"))
});

gulp.task('clean', function () {
    var filePathList = readFileNameList(buildPath);
    for (var i = 0; i < filePathList.length; i++) {
        fs.unlink(filePathList[i]);
    }
    return true;
})
gulp.task('reload', function () {
    browserSync.reload(buildPath);
    //console.log("reload complete at " + new Date().toString());
})

// 静态服务器 + 监听 less/html/js/images/Edox框架源文件
gulp.task('server', function () {
    browserSync.init({
        server: buildPath,
    });
    gulp.watch(developPath + "**/*").on('change', function () {
        runSequence("clean", ["css-dev", "html-dev", "js-dev", "images-dev", "Edox-dev"], "reload");
    });
});


//本地开发执行默认任务
gulp.task('default', function () {
    runSequence("clean", ["css-dev", "html-dev", "js-dev", "images-dev", "Edox-dev"], "server");
});

//执行打包发布任务
gulp.task('product', function () {
    runSequence("clean", ["html", "css", "js", "images", "Edox"]);
});

查看示例(需翻墙)

示例项目,可以整个clone下来操作,更方便使用。

也可以把该项目修改一番加入自己需要的框架以供使用。

使用:

本地开发命令:
cd build   //build文件夹下
gulp

打包发布命令:
gulp product

 

赞(1)
转载请注明来源:Web前端(W3Cways.com) - Web前端学习之路 » 使用gulp搭建前端自动化开发环境
分享到: 更多 (0)