Webpack:如何使用CommonsChunkPlugin将条目捆绑到多个常见块?

时间:2016-03-10 05:24:30

标签: javascript webpack

假设我有两个页面Page1Page2,它们都使用了一些库(供应商),例如jquery backbone我希望将其作为单个文件提取,然后我希望在另一个文件中提取共享模块(不包括供应商),这是webpack配置:

function listFiles(srcpath) {
    return fs.readdirSync(srcpath).filter(function (file) {
        return fs.statSync(path.join(srcpath, file)).isDirectory();
    });
}
var createEntry = function (src) {
    var dest = {
        vendor: ["backbone", "underscore"]
    };
    var files = listFiles(src);
    files.forEach(function (dir) {
        var name = dir;
        dest[name] = src + "/" + dir + "/entry.js";
    });
    return dest;
};

//each sub directory contains a `entry.js` as the entry point for the page
var entries = createEntry("./app/pages");//    {vender:['jquery','backbone'],page1:'src/page1/entry.js',page2:'src/page2/entry.js'    }

var config = {
    resolve: {
        root: path.resolve('./app/'),
        extensions: ['', '.js']
    },

    plugins: [
        new webpack.optimize.CommonsChunkPlugin("vendor", "vendor.js", Infinity),
        new webpack.optimize.CommonsChunkPlugin({
            name: 'common',
            filename: 'common.js',
            minChunks: 2
        })
    ],
    entry: entries,
    output: {
        path: './../main/webapp/static/dist',
        filename: '[name].js',
        publicPath: '/static/dist'
    }
};
module.exports = config;

但是使用上面的配置:

common.js包含webpack运行时,

page1.js包含page1指定的模块和共享模块

page2.js包含page2指定的模块和共享模块

这意味着page1.jspage2.js包含太多的重复代码。

然后我尝试更改配置:

var entries = createEntry("./app/pages");
var chunks = [];
for (var k in entries) {
    if (k === 'vendor')
        continue;
    chunks.push(k);
}


new webpack.optimize.CommonsChunkPlugin("vendor", "vendor.js", Infinity),
new webpack.optimize.CommonsChunkPlugin({
    name: 'common',
    filename: 'common.js',
    minChunks: 2,
    chunks:chunks
}),

然后

common.js包含webpack运行时和供应商库以及共享模块

vendor.js包含webpack运行时和供应商库。

page1.js包含page1指定的模块

page2.js包含第2页指定的模块

它似乎越来越接近,但common.js不应包含供应商

有什么不对吗?

1 个答案:

答案 0 :(得分:13)

如果您需要多个常见的块包,则必须为每个公共包指定所有块详细信息,如in the example所示:

var config = {

    entry: {
        vendor: ["backbone", "underscore"],
        common: "./app/pages/common/entry.js",
        page1: "./app/pages/page1/entry.js",
        page2: "./app/pages/page2/entry.js"
    },

    plugins: [
        new webpack.optimize.CommonsChunkPlugin({
            name: "vendor",
            chunks: ["vendor"]
        }),
        new webpack.optimize.CommonsChunkPlugin({
            name: "common",
            chunks: ["common"]
        })        
    ]
};

请注意,chunks的{​​{1}}选项是指您定位的条目的名称。由于您希望从CommonsChunkPlugin中拆分vendor,因此您必须明确表示您只需要在common公共块中输入vendor,并在vendor中输入相同内容。