鍍金池/ 問答/HTML/ webpack npm run build 打包報(bào)錯(cuò),沒發(fā)現(xiàn)原因在哪,請(qǐng)賜教。

webpack npm run build 打包報(bào)錯(cuò),沒發(fā)現(xiàn)原因在哪,請(qǐng)賜教。

clipboard.png

第一步,報(bào)錯(cuò) webpack.optimize.CommonsChunkPlugin has been removed, please use config.optimization.splitChunks instead. 百度了一下說是webpack4.0中已經(jīng)刪除CommonsChunkPlugin

第二步,替換CommonsChunkPlugin為SplitChunksPlugin時(shí)又報(bào)錯(cuò),沒搞懂是啥意思。

clipboard.png

項(xiàng)目結(jié)構(gòu):

clipboard.png

輸入輸出配置:
entry: path.join(__dirname, '../src/index.js'), // 輸入:項(xiàng)目主文件(入口文件)

output: {       // 輸出
    filename: 'build.[hash:8].js',  // 輸出的文件名
    path: path.join(__dirname, './dist')  // 輸出路徑
}

生成壞境的配置:

webpack.config.client.js 文件

config = merge(baseConfig,{
    entry:{  // 將所用到的類庫單獨(dú)打包
        app: path.join(__dirname, '../src/index.js'),
        vendor: ['vue']
    },
    output:{
        filename: '[name].[chunkhash:8].js',
    },
    module:{
        rules:[
            {
                fallback: 'style-loader',
                use: [
                    'css-loader',
                    {
                        loader: 'postcss-loader',
                        options: {
                            sourceMap: true
                        }
                    },
                    'stylus-loader'
                ]
            }
        ]
    },
    plugins:defaultPluins.concat([
        new ExtractPlugin('styles.[contentHash:8].css'),
        // 將類庫文件單獨(dú)打包出來
        new webpack.optimize.SplitChunksPlugin({
            name: 'vendor'
        }),
      
        // webpack相關(guān)的代碼單獨(dú)打包
        new webpack.optimize.SplitChunksPlugin({
            name: 'runtime'
        })
        
    ]),
    optimization:{
        splitChunks: {
            cacheGroups: {                  // 這里開始設(shè)置緩存的 chunks
                commons: {
                    chunks: 'initial',      // 必須三選一: "initial" | "all" | "async"(默認(rèn)就是異步)
                    minSize: 0,             // 最小尺寸,默認(rèn)0,
                    minChunks: 2,           // 最小 chunk ,默認(rèn)1
                    maxInitialRequests: 5   // 最大初始化請(qǐng)求書,默認(rèn)1
                },  
                vendor: {
                    test: /node_modules/,   // 正則規(guī)則驗(yàn)證,如果符合就提取 chunk
                    chunks: 'initial',      // 必須三選一: "initial" | "all" | "async"(默認(rèn)就是異步)
                    name: 'vendor',         // 要緩存的 分隔出來的 chunk 名稱
                    priority: 10,           // 緩存組優(yōu)先級(jí)
                    enforce: true
                }
            }
        },
        runtimeChunk: true
    }
    
})
回答
編輯回答
硬扛

webpack中fallback這個(gè)屬性,webpack升級(jí)后有些屬性已經(jīng)不支持這樣寫了,推薦一個(gè)項(xiàng)目可以看看webpack4配置webpack4配置

2017年6月21日 03:29