详解用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 相关文章推荐
jQuery 工具函数学习资料
Apr 29 Javascript
javascript scrollTop正解使用方法
Nov 14 Javascript
JavaScript关闭当前页面(窗口)不带任何提示
Mar 26 Javascript
jQuery表格排序组件-tablesorter使用示例
May 26 Javascript
JavaScript中的普通函数与构造函数比较
Apr 07 Javascript
JavaScript String 对象常用方法详解
May 13 Javascript
JavaScript使用键盘输入控制实现数字验证功能
Aug 19 Javascript
利用prop-types第三方库对组件的props中的变量进行类型检测
May 02 Javascript
Vue使用vue-cli创建项目
Sep 01 Javascript
微信小程序实现图片预览功能
Jan 31 Javascript
详解vue-cli项目中的proxyTable跨域问题小结
Feb 09 Javascript
小程序显示弹窗时禁止下层的内容滚动实现方法
Mar 20 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+JS无限级可伸缩菜单详解(简单易懂)
2007/01/02 PHP
PHP仿博客园 个人博客(1) 数据库与界面设计
2013/07/05 PHP
深入理解PHP 数组之count 函数
2016/06/13 PHP
php简单计算权重的方法示例【适合抽奖类应用】
2019/06/10 PHP
基于php解决json_encode中文UNICODE转码问题
2020/11/10 PHP
javascript replace方法与正则表达式
2008/02/19 Javascript
需要做特殊处理的DOM元素属性的访问
2010/11/05 Javascript
IFrame跨域高度自适应实现代码
2012/08/16 Javascript
js 阻止子元素响应父元素的onmouseout事件具体实现
2013/12/23 Javascript
jquery制作居中遮罩层效果分享
2014/02/21 Javascript
JavaScript清空数组元素的两种方法简单比较
2015/07/10 Javascript
JavaScript通过使用onerror设置默认图像显示代替alt
2016/03/01 Javascript
Jquery和Js获得元素标签名称的方法总结
2016/10/08 Javascript
JavaScript中数据类型转换总结
2016/12/25 Javascript
微信小程序 特效菜单抽屉效果实例代码
2017/01/11 Javascript
Vue2.0学习之详解Vue 组件及父子组件通信
2017/12/12 Javascript
解决layui上传文件提示上传异常,实际文件已经上传成功的问题
2018/08/19 Javascript
vue中input的v-model清空操作
2019/09/06 Javascript
[50:27]Secret vs VG 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
Python实现一个简单的MySQL类
2015/01/07 Python
详解Python 模拟实现生产者消费者模式的实例
2017/08/10 Python
Python学生信息管理系统修改版
2018/03/13 Python
python代码过长的换行方法
2018/07/19 Python
Python中类的创建和实例化操作示例
2019/02/27 Python
Python CVXOPT模块安装及使用解析
2019/08/01 Python
python tkinter实现下载进度条及抖音视频去水印原理
2021/02/07 Python
css3实现3D文本悬停改变效果的示例代码
2019/01/16 HTML / CSS
html5中的input新属性range使用记录
2014/09/05 HTML / CSS
雅诗兰黛美国官网:Estee Lauder美国
2016/07/21 全球购物
生物化工工艺专业应届生求职信
2013/10/08 职场文书
洗车工岗位职责
2014/03/15 职场文书
党员政治学习材料
2014/05/14 职场文书
助学贷款贫困证明
2014/09/23 职场文书
女生抽烟检讨书
2014/10/05 职场文书
关于远足的感想
2015/08/10 职场文书
Python实现Telnet自动连接检测密码的示例
2021/04/16 Python