详解用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 相关文章推荐
js二级地域选择的实现方法
Jun 17 Javascript
js获取对象为null的解决方法
Nov 21 Javascript
jQuery延迟加载图片插件Lazy Load使用指南
Mar 25 Javascript
jQuery焦点图轮播插件KinSlideshow用法分析
Jun 08 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
AngularJS Select(选择框)使用详解
Jan 18 Javascript
Bootstrap下拉菜单样式
Feb 07 Javascript
JavaScript之DOM插入更新删除_动力节点Java学院整理
Jul 03 Javascript
VUEJS 2.0 子组件访问/调用父组件的实例
Feb 10 Javascript
Vue侦测相关api的实现方法
May 22 Javascript
用JS实现选项卡
Mar 23 Javascript
JS寄快递地址智能解析的实现代码
Jul 16 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
ubuntu12.04使用c编写php扩展模块教程分享
2013/12/25 PHP
PHP各种异常和错误的拦截方法及发生致命错误时进行报警
2016/01/19 PHP
图片按比例缩放函数
2006/06/26 Javascript
jquery下将选择的checkbox的id组成字符串的方法
2010/11/28 Javascript
HTML中的setCapture和releaseCapture使用介绍
2012/03/21 Javascript
javascript针对DOM的应用实例(一)
2012/04/15 Javascript
jQuery ajax(复习)—Baidu ajax request分离版
2013/01/24 Javascript
Node.js node-schedule定时任务隔多少分钟执行一次的方法
2015/02/10 Javascript
学习JavaScript设计模式之单例模式
2016/01/19 Javascript
js+html5实现canvas绘制网页时钟的方法
2016/05/21 Javascript
bootstrap table配置参数例子
2017/01/05 Javascript
关于Bootstrap按钮组件消除黄框的方法
2017/05/19 Javascript
jQuery选择器之子元素过滤选择器
2017/09/28 jQuery
nodejs实现爬取网站图片功能
2017/12/14 NodeJs
vue组件name的作用小结
2018/05/23 Javascript
浅谈React的最大亮点之虚拟DOM
2018/05/29 Javascript
Bootstrap 时间日历插件bootstrap-datetimepicker配置与应用小结
2019/05/28 Javascript
VUE安装使用教程详解
2019/06/03 Javascript
JS 实现发送短信验证码的“59秒后重新发送验证短信”功能
2019/08/23 Javascript
antd中table展开行默认展示,且不需要前边的加号操作
2020/11/02 Javascript
使用python实现扫描端口示例
2014/03/29 Python
教你用python3根据关键词爬取百度百科的内容
2016/08/18 Python
python3.6+opencv3.4实现鼠标交互查看图片像素
2018/02/26 Python
python实现按行分割文件
2019/07/22 Python
python matplotlib库绘制散点图例题解析
2019/08/10 Python
python在linux环境下安装skimage的示例代码
2020/10/14 Python
Zavvi荷兰:英国大型音像制品和图书游戏零售商
2018/03/22 全球购物
ASP.NET中的身份验证有那些
2012/07/13 面试题
yy婚礼司仪主持词
2014/03/14 职场文书
演讲稿格式
2014/04/30 职场文书
美德少年事迹材料1000字
2014/08/21 职场文书
工商局局长个人对照检查材料思想汇报
2014/09/23 职场文书
2015年医院护理部工作总结
2015/04/23 职场文书
MySQL获取所有分类的前N条记录
2021/05/07 MySQL
详细聊聊Oracle表碎片对性能有多大的影响
2022/03/19 Oracle
利用 Python 的 Pandas和 NumPy 库来清理数据
2022/04/13 Python