详解用webpack的CommonsChunkPlugin提取公共代码的3种方式


Posted in Javascript onNovember 09, 2017

Webpack 的 CommonsChunkPlugin 插件,负责将多次被使用的 JS 模块打包在一起。

CommonsChunkPlugin 能解决的问题

在使用插件前,考虑几个问题:

  1. 对哪些 chunk 进行提取,这决定了 chunks ,children 和 name 要怎么配置
  2. common chunk 是否异步,这决定了 async 怎么配置
  3. common chunk 的粒度,这决定了 minChunks 和 minSize 怎么配置

以下是官方给出的常用的场景:

  1. 提取两个及两个以上 Chunk 的公共代码
  2. 将 Code Split 切割出来的 Chunk「就是子 Chunk」,提取到父 Chunk
  3. 将 Code Split 切割出来的 Chunk,提取到一个新的异步加载的 Chunk
  4. 提取某个类似 jquery 或 react 的代码库

前面我们实现了 多页面分离资源引用,按需引用JS和css

但有一个问题:最后生成的3个js,都有重复代码,我们应该把这部分公共代码单独提取出来。

方式一,传入字符串参数

new webpack.optimize.CommonsChunkPlugin(‘common.js'), // 默认会把所有入口节点的公共代码提取出来,生成一个common.js

var HtmlWebpackPlugin = require('html-webpack-plugin');
var webpack = require('webpack');

var extractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
  // entry是入口文件,可以多个,代表要编译那些js
  //entry:['./src/main.js','./src/login.js','./src/reg.js'],

  entry:
  {
    'main':'./src/main.js',
    'user':['./src/login.js','./src/reg.js'],
    'index':['./src/index.js']
  },

  externals:{
    'jquery':'jQuery'
  },

  module:{
    loaders:[
      // {test:/\.css$/,loader:'style-loader!css-loader'},
      {test:/\.css$/,loader:extractTextPlugin.extract('style','css')}
    ],
  },

  output:{
    path: __dirname+'/build/js', // 输出到那个目录下(__dirname当前项目目录)
    filename:'[name].js' //最终打包生产的文件名
  },

  plugins:[
    new HtmlWebpackPlugin({
      filename: __dirname+'/build/html/login-build.html',
      template:__dirname+'/src/tpl/login.html',
      inject:'body',
      hash:true,
      chunks:['main','user','common.js']  // 这个模板对应上面那个节点
    }),

    new HtmlWebpackPlugin({
      filename: __dirname+'/build/html/index-build.html',
      template:__dirname+'/src/tpl/index.html',
      inject:'body',
      hash:true,
      chunks:['index','common.js']  // 这个模板对应上面那个节点
    }),

    // css抽取
    new extractTextPlugin("[name].css"),

    // 提供公共代码
    new webpack.optimize.CommonsChunkPlugin('common.js'), // 默认会把所有入口节点的公共代码提取出来,生成一个common.js
  ]
};

方式二,有选择的提取公共代码

// 提供公共代码
// 默认会把所有入口节点的公共代码提取出来,生成一个common.js
// 只提取main节点和index节点
new webpack.optimize.CommonsChunkPlugin('common.js',['main','index']),

方式三,有选择性的提取(对象方式传参)

推荐

new webpack.optimize.CommonsChunkPlugin({
      name:'common', // 注意不要.js后缀
      chunks:['main','user','index']
    }),

通过CommonsChunkPlugin,我们把公共代码专门抽取到一个common.js,这样业务代码只在index.js,main.js,user.js

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
超级强大的表单验证
Jun 26 Javascript
JavaScript 编程引入命名空间的方法
Jun 29 Javascript
javascript new一个对象的实质
Jan 07 Javascript
JavaScript中的toLocaleLowerCase()方法使用详解
Jun 06 Javascript
深入浅出ES6新特性之函数默认参数和箭头函数
Aug 01 Javascript
js获取form表单所有数据的简单方法
Aug 18 Javascript
jquery+css3问卷答题卡翻页动画效果示例
Oct 26 Javascript
vue父组件向子组件动态传值的两种方法
Nov 11 Javascript
基于openlayers4实现点的扩散效果
Aug 17 Javascript
vue 中滚动条始终定位在底部的方法
Sep 03 Javascript
基于element-ui封装可搜索的懒加载tree组件的实现
May 22 Javascript
javascript实现贪吃蛇小游戏
Jul 28 Javascript
Angularjs渲染的 using 指令的星级评分系统示例
Nov 09 #Javascript
jQuery实现动态添加节点与遍历节点功能示例
Nov 09 #jQuery
简单实现jquery隔行变色
Nov 09 #jQuery
基于Datatables跳转到指定页的简单实例
Nov 09 #Javascript
浅谈vue2 单页面如何设置网页title
Nov 08 #Javascript
jQuery实现的简单无刷新评论功能示例
Nov 08 #jQuery
js使用xml数据载体实现城市省份二级联动效果
Nov 08 #Javascript
You might like
php cookie的操作实现代码(登录)
2010/12/29 PHP
PHP计划任务、定时执行任务的实现代码
2011/04/23 PHP
php输出1000以内质数(素数)示例
2014/02/16 PHP
PHP排序算法类实例
2015/06/17 PHP
php版本CKEditor 4和CKFinder安装及配置方法图文教程
2019/06/05 PHP
jQuery+css+html实现页面遮罩弹出框
2013/03/21 Javascript
让JavaScript中setTimeout支持链式操作的方法
2015/06/19 Javascript
javascript实现textarea中tab键的缩排处理方法
2015/06/26 Javascript
jquery常用函数与方法汇总
2015/09/01 Javascript
js省市县三级联动效果实例
2020/04/15 Javascript
喜大普奔!jQuery发布 3.0 最终版
2016/06/12 Javascript
微信小程序tabBar模板用法实例分析【附demo源码下载】
2017/11/28 Javascript
js中getter和setter用法实例分析
2018/08/14 Javascript
Vue数据双向绑定的深入探究
2018/11/27 Javascript
详解微信小程序文件下载--视频和图片
2019/04/24 Javascript
vue中keep-alive内置组件缓存的实例代码
2020/04/16 Javascript
使用Vue+Django+Ant Design做一个留言评论模块的示例代码
2020/06/01 Javascript
浅谈JavaScript中this的指向问题
2020/07/28 Javascript
Vue 数据响应式相关总结
2021/01/28 Vue.js
react项目从新建到部署的实现示例
2021/02/19 Javascript
[00:44]2016完美“圣”典 风云人物:Mikasa宣传片
2016/12/07 DOTA
Python操作MongoDB数据库PyMongo库使用方法
2015/04/27 Python
Numpy数组的保存与读取方法
2018/04/04 Python
快速解决PyCharm无法引用matplotlib的问题
2018/05/24 Python
pyqt5实现按钮添加背景图片以及背景图片的切换方法
2019/06/13 Python
python实现俄罗斯方块小游戏
2020/04/24 Python
增大python字体的方法步骤
2020/07/05 Python
python 匿名函数与三元运算学习笔记
2020/10/23 Python
完美解决Pycharm中matplotlib画图中文乱码问题
2021/01/11 Python
英国和国际包裹递送:ParcelCompare
2019/08/26 全球购物
爱尔兰橄榄球店:Irish Rugby Store
2019/12/05 全球购物
大学生村官个人对照检查材料(群众路线)
2014/09/26 职场文书
2014年房地产个人工作总结
2014/12/20 职场文书
个人简历求职信范文
2015/03/20 职场文书
nginx基于域名,端口,不同IP的虚拟主机设置的实现
2021/03/31 Servers
使用vue-element-admin框架从后端动态获取菜单功能的实现
2021/04/29 Vue.js