首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >供应商代码即使在webpack配置中拆分后仍在bundle.js文件中

供应商代码即使在webpack配置中拆分后仍在bundle.js文件中
EN

Stack Overflow用户
提问于 2017-07-01 17:54:33
回答 1查看 341关注 0票数 2

使用下面的webpack配置,我仍然可以在bundle.js文件中获得供应商代码。(即使在代码拆分之后,bundle.js的大小仍然保持不变)。我希望供应商代码不应该出现在bundle.js中

访问了某些链接,但没有任何帮助。(https://github.com/dmachat/angular-webpack-cookbook/wiki/Split-app-and-vendors)

代码语言:javascript
复制
'use strict';

 var webpack = require('webpack');

module.exports = {
context: __dirname + '/client/js',
entry: {
    source: ['./init.jsx'],
    vendor: ['react',
        'react-dom',
        'redux',
        'axios',
        'ramda-fantasy',
        'ramda',
        'react-json-tree',
        'react-tooltip',
        'validator']
},
output: {
    filename: "[name].bundle.js"
},
resolve: {
    modulesDirectories: ['node_modules'],
    extensions: ['', '.js', '.jsx']
},
module: {
    loaders: [
        { test: /\.json$/, loader: 'json-loader' },
        {
            loader: 'babel-loader',
            exclude: /node_modules/,
            query: {
                presets: ['react', 'es2015', 'stage-0']
            }
        },
        { test: /\.css$/, loader: "css-loader" },
    ]
},

plugins: [new webpack.optimize.CommonsChunkPlugin({
    name: 'vendor',
    chunks: ['vendor'],
    filename: 'vendor.js',
    minChunks: Infinity
})
],

devtool: 'source-map',

node: {
    console: true,
    fs: 'empty',
    net: 'empty',
    tls: 'empty'
},

 target: 'web'
};
EN

回答 1

Stack Overflow用户

发布于 2018-11-14 09:31:12

根据Webpack文档here的说法,CommonsChunkPlugin已经被弃用,并在版本4之后被删除。原因可能是-这可能是为什么它不适用于你,它已经被证明在异步区块上效率低下,而且也很难使用(例如:当子模块设置为真时,这只适用于直接子模块),因此具有共享模块的3级依赖项不会包含在配置中。

请选择SplitChunksPlugin。这应该可以解决您的问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44859585

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档