详解用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 相关文章推荐
Node.js入门教程:在windows和Linux上安装配置Node.js图文教程
Aug 14 Javascript
javascript动态创建表格及添加数据实例详解
May 13 Javascript
基于JavaScript实现一定时间后去执行一个函数
Dec 14 Javascript
DeviceOne 让你一见钟情的App快速开发平台
Feb 17 Javascript
基于JS实现数字+字母+中文的混合排序方法
Jun 06 Javascript
Javascript中获取浏览器类型和操作系统版本等客户端信息常用代码
Jun 28 Javascript
JS及PHP代码编写八大排序算法
Jul 12 Javascript
JS+CSS3模拟溢出滚动效果
Aug 12 Javascript
jquery的checkbox,radio,select等方法小结
Aug 30 Javascript
利用node.js实现自动生成前端项目组件的方法详解
Jul 12 Javascript
Vue 实例事件简单示例
Sep 19 Javascript
通过实例解析javascript Date对象属性及方法
Nov 04 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中创建并处理图象
2006/10/09 PHP
php 设计模式之 单例模式
2008/12/19 PHP
PHP开发中四种查询返回结果分析
2011/01/02 PHP
php selectradio和checkbox默认选择的实现方法详解
2013/06/29 PHP
PHP中实现crontab代码分享
2015/03/26 PHP
php仿微信红包分配算法的实现方法
2016/05/13 PHP
js以对象为索引的关联数组
2010/07/04 Javascript
js获取class的所有元素
2013/03/28 Javascript
jquery 面包屑导航 具体实现
2013/06/05 Javascript
jQuery在html有效在jsp无效的原因及解决方法
2013/08/02 Javascript
javascript内置对象arguments详解
2014/03/16 Javascript
javascript实现iframe框架延时加载的方法
2014/10/30 Javascript
JS使用eval解析JSON的注意事项分析
2015/11/14 Javascript
深入理解基于vue-cli的vuex配置
2017/07/24 Javascript
JS加密插件CryptoJS实现的Base64加密示例
2020/08/16 Javascript
js canvas实现写字动画效果
2018/11/30 Javascript
jQuery鼠标滑过横向时间轴样式(代码详解)
2019/11/01 jQuery
jQuery列表动态增加和删除的实现方法
2020/11/05 jQuery
python刷投票的脚本实现代码
2014/11/08 Python
详解Django中的form库的使用
2015/07/18 Python
Python中实现最小二乘法思路及实现代码
2018/01/04 Python
python中round函数保留两位小数的方法
2020/12/04 Python
CSS3 Media Queries详细介绍和使用实例
2014/05/08 HTML / CSS
如何使用css3实现一个类在线直播的队列动画的示例代码
2020/06/17 HTML / CSS
法国美发器材和产品购物网站:Beauty Coiffure
2016/12/05 全球购物
NARS化妆品官方商店:美国彩妆品牌
2017/08/26 全球购物
为什么需要版本控制
2016/10/28 面试题
大二学生职业生涯规划书
2014/02/05 职场文书
《影子》教学反思
2014/02/21 职场文书
西岭雪山导游词
2015/02/06 职场文书
放假通知格式
2015/04/14 职场文书
催款函范文
2015/06/24 职场文书
班级联欢会主持词
2015/07/03 职场文书
导游词之包公祠
2019/11/25 职场文书
python基础学习之生成器与文件系统知识总结
2021/05/25 Python
Android RecyclerView实现九宫格效果
2022/06/28 Java/Android