webpack4.0 watch

1.打包多页应用

多个entry打包多个页面为例

module.exports = {
  mode: 'development',
  entry: {
    index: './src/index.js',
    other: './src/other.js',
  },
  output: {
    filename: '[name].js',
    path: path.resolve(__dirname, 'dist')
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: './src/index.html',
      filename: 'index.html',
      chunks: ['index', 'other']
    }),
    new HtmlWebpackPlugin({
      template: './src/index.html',
      filename: 'other.html',
      chunks: ['other']
    })
  ]
}

首先output的filename中,用变量name打包不同的js,创建各自依赖关系。然后插件“html-webpack-plugin插件的参数中,字段chunks指定打包后的html文件该引用哪个JS文件”

2.配置sourceMap

生产环境中生成的代码已经被压缩,报错后很难定位。webpack支持sourceMap(源码映射),可以很方便的解决此类烦恼。代码如下:

module.exports = {
  mode: 'development',
  entry: {
    index: './src/index.js'
  },
  output: {
    filename: '[name].js',
    path: path.resolve(__dirname, 'dist')
  },
//你可以直接使用 SourceMapDevToolPlugin/EvalSourceMapDevToolPlugin 来替代使用 devtool 选项,因为它有更多的选项。切勿同时使用 devtool 选项和 SourceMapDevToolPlugin/EvalSourceMapDevToolPlugin 插件。devtool 选项在内部添加过这些插件,所以你最终将应用两次插件。
  devtool: 'source-map',  // 会多生成一个.map文件,因此打包和构建速度可能会略慢。常见的还有‘eval-source-map’,调试时与source-map方式基本没区别,只是不会生成.map文件。还有多种sourceMap方式,具体用法自行测试
  module: {
    rules: [
    ...
 ...
}

4.watch的用法

watch提供了和webpack-dev-server中的“hot”字段类似的功能,只是它是实时打包,"hot"是实时刷新。watch还有自己的配置项(和watch同级,字段名为watchOption)。

  output: {
    ...
  },
  devServer: {
    ...
  },
  watch: true,
  watchOptions: {
    poll: 1000,  // 每秒查询1000次
    aggreatement: 500, // 防抖,节流
    ignored: /node_modules/  //不需要监控的文件
  },
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、入坑初探 1. 设置项目为私有 我们只需要在package.json文件中配置,因为是私有项目不需要向外部暴露...
    zxhnext阅读 2,054评论 0 15
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 5,319评论 4 31
  • 熟悉 webpack 与 webpack4 配置。 webpack4 相对于 3 的最主要的区别是所谓的零配置,但...
    yichen_china阅读 1,425评论 0 3
  • 最近朋友圈被《头号玩家》刷爆了,斯皮尔伯格一个资深电影导演,把对过去经典的致敬,对未来的憧憬浓缩在这一部电影中,可...
    lihuanji阅读 699评论 0 5
  • 姓名:黄礼龙 公司:余姚大发化纤有限公司 2017.6.16-18上海盛和塾264期 《六项精进》学员 组号:乐观...
    黄礼龙阅读 124评论 0 0