详解用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 相关文章推荐
javascript编程起步(第一课)
Jan 10 Javascript
jQuery 源码分析笔记(5) jQuery.support
Jun 19 Javascript
javascript中[]和{}对象使用介绍
Mar 20 Javascript
jquery实现input输入框实时输入触发事件代码
Jan 28 Javascript
用html5 js实现点击一个按钮达到浏览器全屏效果
May 28 Javascript
正则表达式(语法篇推荐)
Jun 24 Javascript
create-react-app 修改为多入口编译的方法
Aug 01 Javascript
vue实现element-ui对话框可拖拽功能
Aug 17 Javascript
微信小程序实现侧边栏分类
Oct 21 Javascript
angular8和ngrx8结合使用的步骤介绍
Dec 01 Javascript
vue框架中props的typescript用法详解
Feb 17 Javascript
jdk1.8+vue elementui实现多级菜单功能
Sep 24 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
《星际争霸II》全新指挥官斯台特曼现已上线
2020/03/08 星际争霸
header中Content-Disposition的作用与使用方法
2012/06/13 PHP
浅析关于PHP位运算的简单权限设计
2013/06/30 PHP
微信公众平台之快递查询功能用法实例
2015/04/14 PHP
读jQuery之十一 添加事件核心方法
2011/07/31 Javascript
在Javascript中 声明时用"var"与不用"var"的区别
2013/04/15 Javascript
express的中间件cookieParser详解
2014/12/04 Javascript
浅析jQuery移动开发中内联按钮和分组按钮的编写
2015/12/04 Javascript
基于Node.js实现nodemailer邮件发送
2016/01/26 Javascript
浅谈jQuery中的checkbox问题
2016/08/10 Javascript
scrapyd schedule.json setting 传入多个值问题
2019/08/07 Javascript
关于vue.js中实现方法内某些代码延时执行
2019/11/14 Javascript
Python计算三角函数之asin()方法的使用
2015/05/15 Python
简单谈谈python中的Queue与多进程
2016/08/25 Python
详解Tensorflow数据读取有三种方式(next_batch)
2018/02/01 Python
Python中将dataframe转换为字典的实例
2018/04/13 Python
python安装scipy的方法步骤
2019/06/26 Python
Django基础三之视图函数的使用方法
2019/07/18 Python
django基于存储在前端的token用户认证解析
2019/08/06 Python
Python实现计算图像RGB均值方式
2020/06/04 Python
日本热销NO.1胶原蛋白冻:Aishitoto爱希特多
2019/06/20 全球购物
为女性购买传统的印度服装和婚纱:Kalkifashion
2019/07/22 全球购物
俄罗斯连接商品和买家的在线平台:goods.ru
2020/11/30 全球购物
屈臣氏菲律宾官网:Watsons菲律宾
2020/06/30 全球购物
.net C#面试题
2012/08/28 面试题
物流毕业生个人的自我评价
2014/02/13 职场文书
大学生学习2014全国两会心得体会
2014/03/13 职场文书
矿泉水广告词
2014/03/20 职场文书
四风对照检查材料范文
2014/09/27 职场文书
公司租房协议书范本
2014/10/08 职场文书
盗窃案辩护词
2015/05/21 职场文书
生死牛玉儒观后感
2015/06/11 职场文书
大学毕业谢师宴致辞
2015/07/27 职场文书
Python深度学习之Pytorch初步使用
2021/05/20 Python
Golang中channel的原理解读(推荐)
2021/10/16 Golang
详解Redis的三种常用的缓存读写策略步骤
2022/05/06 Redis