专栏名称: Coderfei
前端
目录
相关文章推荐
参考消息  ·  莫迪到访前,美国放话施压 ·  22 小时前  
卢克文工作室  ·  他们为什么“穷”得如此稳定? ·  昨天  
卢克文工作室  ·  天启特朗普、西厂马斯克 ·  2 天前  
参考消息  ·  俄罗斯一油轮突发爆炸! ·  2 天前  
参考消息  ·  印度“从零开始”研发AI芯片 ·  3 天前  
51好读  ›  专栏  ›  Coderfei

Gulp 和 webpack 入门

Coderfei  · 掘金  ·  · 2019-05-25 07:45

正文

阅读 37

Gulp 和 webpack 入门

Gulp

Gulp 是什么?

gulp是一个基于流的构建工具,可以自动执行指定的任务,简洁且高效

Gulp 能做什么?

  1. 开发环境下,想要能够按模块组织代码,监听实时变化
  2. css/js预编译,postcss等方案,浏览器前缀自动补全等
  3. 条件输出不同的网页,比如app页面和mobile页面
  4. 线上环境下,我想要合并、压缩 html/css/javascritp/图片,减少网络请求,同时降低网络负担
  5. 等等...

安装 Gulp

npm install -g gulp     //全局安装
npm install --save-dev gulp //安装到当前项目并在package.json中添加依赖复制代码

核心 API 介绍

gulp.task task(name[, deps], fn)

task()方法用于定义任务,传入名字、依赖任务数组、函数即可,gulp会先执行任务数组,结束后调用定义的函数,可以通过此手段控制任务的执行顺利。

例子:要定义一个任务build来执行css、js、imgs这三个任务,我们可以通过指定一个任务数组而不是函数来完成。

gulp.task('build', ['css', 'js', 'imgs']);复制代码

gulp.src src(globs[, options])

src()方法输入一个glob或者glob数组,然后返回一个可以传递给插件的数据流

Gulp使用 node-glob 来从你指定的glob里面获取文件:

  • app.js 精确匹配
  • *.js 能匹配js后缀的文件
  • **/*.js 能匹配多级目录下的js文件(也包含当前目录下)
  • !js/app.js 精确排除

例子:js目录下包含了压缩和未压缩的js文件,我们想要压缩还没有被压缩的文件

gulp.src(['js/**/*.js', '!js/**/*.min.js'])
复制代码

gulp.dest dest(path[, options])

dest()方法用来写文件,第一个参数表示最终输出的目录名。注意,它无法允许我们指明最终输出的文件名,只能指定输出文件夹名,而且在文件夹不存在的情况下会自动创建。

例子:把开发目录src下的js文件输出到部署目录dist下

gulp.src('src/**/*.js')
  .pipe(gulp.dest('dist'))复制代码

gulp.watch watch(globs[, opts], cb) or watch(globs[, opts], tasks)

watch()方法可以监听文件,它接受一个glob或者glob数组以及一个任务数组来执行回调
// 当templates目录下的模板文件发生变化,自动执行编译任务

gulp.task('watch', function (event) {
  gulp.watch('templates/*.tmpl.html', ['artTemplate']);
  console.log('Event type: ' + event.type); // added, changed, or deleted   
  console.log('Event path: ' + event.path); // The path of the modified file
});
复制代码

Gulp.watch()的另一个非常好的特性是返回watcher对象

  • watcher对象可以监听很多事件:
    • change 文件变化时触发
    • end 在watcher结束时触发
    • error 在出现error时触发
    • ready 在文件被找到并正被监听时触发
    • nomatch 在glob没有匹配到任何文件时触发
  • Watcher对象也包含了一些可以调用的方法:
    • watcher.end() 停止watcher
    • watcher.files() 返回watcher监听的文件列表
    • watcher.add(glob) 将与指定glob相匹配的文件添加到watcher(也接受可选的回调当第二个参数)
    • watcher.remove(filepath) 从watcher中移除个别文件


任务会让所有的文件匹配js/*.js,并且执行JSHint,然后打印输出结果,取消文件缩进,最后把他们合并起来,保存为build/app.js,整个过程如下图所示:

var gulp = require('gulp'),
    jshint = require('gulp-jshint'),
    uglify = require('gulp-uglify'),
    concat = require('gulp-concat');

gulp.task('js', function () {
   return gulp.src('js/*.js')
      .pipe(jshint())
      .pipe(jshint.reporter('default'))
      .pipe(uglify())
      .pipe(concat('app.js'))
      .pipe(gulp.dest('build'));
});复制代码

Webpack

webpack 是什么?

webpack是模块化管理工具,使用webpack可以对模块进行压缩、预处理、按需打包、按需加载等。

webpack 有哪些重要特征?

插件化 :webpack本身非常灵活,提供了丰富的插件接口。基于这些接口,webpack开发了很多插件作为内置功能。
速度快 :webpack使用异步IO以及多级缓存机制。所以webpack的速度是很快的,尤其是增量更新。
丰富的Loaders :loaders用来对文件做预处理。这样webpack就可以打包任何静态文件。
高适配性 :webpack同时支持 AMD / CommonJs / ES6 模块方案。webpack会静态解析你的代码,自动帮你管理他们的依赖关系。此外,webpack对第三方库的兼容性很好。
代码拆分 :webpack可以将你的代码分片,从而实现按需打包。这种机制可以保证页面只加载需要的JS代码,减少首次请求的时间。
优化 :webpack提供了很多优化机制来减少打包输出的文件大小,不仅如此,它还提供了hash机制,来解决浏览器缓存问题。
开发模式友好 :webpack为开发模式也提供了很多辅助功能。比如SourceMap、热更新等。
使用场景多 :webpack不仅适用于 web应用 场景,也适用于 Webworkers Node.js 场景

webpack 如何最佳配置?

webpack官方提供的配置方法是通过module.exports返回一个json,但是这种场景不灵活,不能适配多种场景。
比如要解决:production模式和development模式,webpack的配置是有差异的,大致有两种思路。
1、两份配置文件 webpack.config.production.js/webpack.config.development.js ,然后不同场景下,使用不同的配置文件。
2、通过module.exports返回函数,该函数能接受参数。

相对来说,第一种更简单,但是重复配置多;第二种更灵活,推荐第二种方式。
那么,按返回函数的方式的配置代码架子如下:

module.exports = function(env) {
    return {
        context: config.context,
        entry: config.src,
        output: {
            path: path.join(config.jsDest, project),
            filename: '[name].js',
            chunkFilename: '[name].[chunkhash:8].js',
            publicPath: '/assets/' + project + '/'
        },
        devtool: "eval",
        watch: false,
        profile: true,
        cache: true,
        module: {
            loaders: getLoaders(env)
        },
        resolve: {
            alias: getAlias(env)
        },
        plugins: getPlugins(env)
    };
}
复制代码

其中关键的配置这儿简单介绍如下,后续的系列博客会根据每个点详细介绍。
context :上下文。
entry :入口文件,是所有依赖关系的入口,webpack从这个入口开始静态解析,分析模块之间的依赖关系。







请到「今天看啥」查看全文