当前项目结构
data:image/s3,"s3://crabby-images/a2a8d/a2a8d7cce3440b300653645ee0c65b155aad8fc0" alt=""
其中
- Greeter.js 引用了 config.json
- main.js 和 second.js 都引用了 Greeter.js
- main.js 还引用了 onlyformain.js
- second.js 还引用了 onlyforsecond.js
代码如下
// config.json
{
"greetText": "Hi there and greetings from JSON!"
}
// Greeter.js
var config = require('./config.json');
module.exports = function() {
var greet = document.createElement('div');
greet.textContent = config.greetText;
greet.innerText = config.greetText;
console.log(config.greetText)
return greet;
};
// main.js
import 'babel-polyfill'
import './OnlyForMain'
var greeter = require("./Greeter.js")
document.getElementById('root').appendChild(greeter());
console.log("this is from main.js")
// second.js
import 'babel-polyfill'
import './OnlyForSecond'
var greeter = require("./Greeter.js")
document.getElementById('root').appendChild(greeter());
console.log("this is from second.js")
// onlyformain.js
var config = require('./config.json');
module.exports = function() {
console.log("this is only for main")
return {};
};
// onlyforsecond.js
var config = require('./config.json');
module.exports = function() {
console.log("this is only for second")
return {};
};
webpack 配置
data:image/s3,"s3://crabby-images/17538/17538e90deaf148c52e37224cc2e650105a7d1ed" alt=""
当配置 commonChunkPlugin 参数,结果如下:
Case 1
data:image/s3,"s3://crabby-images/6d568/6d568954864e2b3af87ca2d1c22cf0b5b6c9fce1" alt=""
命令行
data:image/s3,"s3://crabby-images/3b65b/3b65bb173adf32f74ecbdec0437aec1416b6e558" alt=""
打包后
data:image/s3,"s3://crabby-images/4c810/4c810706f8c0db2cd8e0c9def926aa3fa7b6d630" alt=""
没有后缀
Case2
data:image/s3,"s3://crabby-images/ca9a1/ca9a1e4a367800981e2f1faa0cb010ee1511293b" alt=""
命令行
data:image/s3,"s3://crabby-images/2bcc0/2bcc0b7fec1cdc659f9fdbf3d20bca8505c53359" alt=""
提出了公共js - init.js
Case3
data:image/s3,"s3://crabby-images/e7206/e7206d42620e4aa4fb550a7720084ccbe7016bf1" alt=""
命令行
data:image/s3,"s3://crabby-images/c0a14/c0a14f63f933344632da7f70d7f217ed283eda8d" alt=""
Case4
data:image/s3,"s3://crabby-images/ce0b0/ce0b076f03d78891c71aa91631ef28c66e1105e3" alt=""
命令行
data:image/s3,"s3://crabby-images/453a7/453a761a578dd40f70d6ad237638f52c566e4343" alt=""
**assert 名称 和 chunk 名称 不一样了 **
Case5
data:image/s3,"s3://crabby-images/ec0a5/ec0a5610990a07eaf469b76e6d2fef85221119e8" alt=""
命令行
data:image/s3,"s3://crabby-images/b32c5/b32c5cc70f7cb9f136b4c1069a794409e51a2636" alt=""
Case6
data:image/s3,"s3://crabby-images/ca32f/ca32f7ea41d5f7004419e7ad860cc8081ac9cd8e" alt=""
命令行
data:image/s3,"s3://crabby-images/9fd7b/9fd7b39955ccd241bb8867dc4af3ca92c6edc18a" alt=""
此时common.js中仅仅有module-require函数
Case7
data:image/s3,"s3://crabby-images/88d1f/88d1fb317e7d9f990409fb10aa9f190393a4f367" alt=""
命令行
data:image/s3,"s3://crabby-images/fbc3e/fbc3e1f36ec37ce04dfbf38d9ce42ad4ecd4fc16" alt=""
此时common.js提取出了config.json和Greeter.js
Case8
data:image/s3,"s3://crabby-images/3f90c/3f90c7a75646786a9f71e24b8579826055d08744" alt=""
命令行
data:image/s3,"s3://crabby-images/f7c72/f7c72f087df8edd22db1be8aa20a466e4f5ccaa6" alt=""
common.js提取出了所有的js,此时 main.js 和 second.js中的代码仅有一行
webpackJsonp([0,1],[]);
Case9
data:image/s3,"s3://crabby-images/ffaf5/ffaf590a75434d4828cd01e69d60792c0a3f4363" alt=""
命令行
data:image/s3,"s3://crabby-images/11037/1103758827683ee9554d752fc0220df91b7675d6" alt=""
**仅仅提出了 module-require 公共部分 ,其他公共模块并不抽取 **
Case 10
data:image/s3,"s3://crabby-images/83e27/83e27ec68882f1ca72138a44ba34e457b4b7ab01" alt=""
命令行
data:image/s3,"s3://crabby-images/5d8a5/5d8a5cdd03e9f22d0847b1b14980f3406766bd6a" alt=""
Case11
data:image/s3,"s3://crabby-images/433ec/433ec559e006ef59f7fd0426cf9f9820b1fd750b" alt=""
命令行
data:image/s3,"s3://crabby-images/1f747/1f7472acac0ea09112c9a2dcb81a37a364a4196b" alt=""
总结
CommonsChunkPlugin
options.name或options.names(string | string []):公共块的块名称。 可以通过传递现有块的名称来选择现有块。 如果传递一个字符串数组,这等于为每个块名称多次调用插件。 如果省略并且options.async或options.children设置为所有块,则使用options.filename作为块名。
options.filename(string):公共块的文件名模板。 可以包含与output.filename相同的占位符。 如果省略,原始文件名不会被修改(通常为output.filename或output.chunkFilename)。
options.minChunks(number | Infinity | function(module,count) - > boolean):在移动到公共块之前需要包含一个模块的块的最小数量。 该数字必须大于或等于2且小于或等于块的数量。 传递无限只是创建公共块,但不移动模块。 通过提供一个函数,你可以添加自定义逻辑。 (默认为块的数量)
options.chunks(string []):按块名称选择源块。 块必须是公共块的子节点。 如果省略,则选择所有条目块。
options.children(boolean):如果true,则选择公共块的所有子节点
options.async(boolean | string):如果为true,将创建一个新的异步公共块作为options.name的子节点和options.chunks的子节点。 它与options.chunks并行加载。 可以通过提供所需的字符串而不是true来更改输出文件的名称。
options.minSize(number):创建公共块之前所有公共模块的最小大小。
网友评论