2017-05-27 86 views
0

我使用CommonsChunkPlugin來拆分我的供應商包。我也有ExtractTextPlugin提取CSS到一個文件。但是,由於某種原因,我也得到vendor.cssWebpack包拆分commonschunk插件

這裏是我的WebPack配置:

const config = { 
    output: { 
    publicPath: '/blaze-assets/', 
    }, 

    cache: isDebug, 

    stats: { 
    colors: true, 
    reasons: isDebug, 
    hash: isVerbose, 
    version: isVerbose, 
    timings: true, 
    chunks: isVerbose, 
    chunkModules: isVerbose, 
    cached: isVerbose, 
    cachedAssets: isVerbose, 
    }, 

    plugins: [ 
    new ExtractTextPlugin({ 
     filename: isDebug ? '[name].css' : '[name].[chunkhash].css', 
     allChunks: true, 
    }), 
    new webpack.LoaderOptionsPlugin({ 
     minimize: true, 
     debug: isDebug, 
    }), 
    ], 

    resolve: { 
    extensions: ['.webpack.js', '.web.js', '.js', '.jsx', '.json'], 
    modules: [ 
     path.resolve('./src'), 
     'node_modules', 
    ] 
    }, 

    module: { 
    rules: [ 
     { 
     test: /\.jsx?$/, 
     include: [ 
      path.resolve(__dirname, '../src'), 
     ], 
     loader: 'babel-loader', 
     }, { 
     test: /\.(scss|css)$/, 
     use: ExtractTextPlugin.extract({ 
      fallback: 'style-loader', 
      use: [ 
      'css-loader', 
      'sass-loader', 
      ] 
     }) 
     }, { 
     test: /\.txt$/, 
     loader: 'raw-loader', 
     }, { 
     test: /\.(otf|png|jpg|jpeg|gif|svg|woff|woff2)(\?v=[0-9]\.[0-9]\.[0-9])?$/, 
     loader: 'url-loader?limit=10000', 
     }, { 
     test: /\.(eot|ttf|wav|mp3)(\?v=[0-9]\.[0-9]\.[0-9])?$/, 
     loader: 'file-loader', 
     }, { 
     test: /\.jade$/, 
     loader: 'jade-loader', 
     } 
    ], 
    }, 
}; 

// 
// Configuration for the client-side bundles 
// ----------------------------------------------------------------------------- 
let clientBundles = {} 

Object.keys(bundles).forEach(function (bundle) { 
    clientBundles[bundle] = [ 
    'bootstrap-loader', 
    `./src/bundles/${bundle}/index.js` 
    ] 
}) 

merge(
    clientBundles, 
    { 
    'embedWidget': ['./src/components/Widgets/EmbedWidget/widgetLoader.js'] 
    }, 
) 

const clientConfig = extend(true, {}, config, { 
    entry: clientBundles, 
    output: { 
    path: path.join(__dirname, '../build/public/blaze-assets/'), 
    filename: isDebug ? '[name].js' : '[name].[chunkhash].js', 
    chunkFilename: isDebug ? '[name].chunk.js' : '[name].[chunkhash:8].chunk.js', 
    }, 
    node: { 
    fs: "empty" 
    }, 
    // Choose a developer tool to enhance debugging 
    // http://webpack.github.io/docs/configuration.html#devtool 
    devtool: isDebug ? 'cheap-module-source-map' : false, 
    plugins: [ 
    // Move modules that occur in multiple entry chunks to a new entry chunk (the commons chunk). 
    // http://webpack.github.io/docs/list-of-plugins.html#commonschunkplugin 
    new webpack.optimize.CommonsChunkPlugin({ 
     name: 'vendor', 
     minChunks: function (module) { 
     // This prevents stylesheet resources with the .css or .scss extension 
     // from being moved from their original chunk to the vendor chunk 
     if(module.resource && (/^.*\.(css|scss)$/).test(module.resource)) { 
      return false; 
     } 
     return module.context && module.context.indexOf("node_modules") !== -1; 
     }, 
    }), 
    ...config.plugins, 
    new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/), 
    new webpack.DefinePlugin({ 
     ...GLOBALS, 
     'process.env.BROWSER': true 
    }), 
    ...(!isDebug ? [ 
     new webpack.optimize.UglifyJsPlugin({ 
     compress: { 
      // jscs:disable requireCamelCaseOrUpperCaseIdentifiers 
      screw_ie8: true, 

      // jscs:enable requireCamelCaseOrUpperCaseIdentifiers 
      warnings: isVerbose, 
      unused: true, 
      dead_code: true, 
     }, 

     }), 
     new webpack.optimize.AggressiveMergingPlugin(), 
    ] : []), 
    new AssetsPlugin({ 
     path: path.join(__dirname, '../build'), 
     filename: 'assets.json', 
     prettyPrint: true, 
    }), 
    ], 
}); 

我也跟着一切按照該文檔,但無法弄清楚什麼是錯在配置?我正在使用webpack 2extract-text-webpack-plugin: 2.1.0

webpack輸出看起來像這樣,它在輸出中有vendor.css這不是預期的。 enter image description here

回答

0

對node_modules下的SCSS/CSS文件使用不同的加載程序配置,不要將ExtractTextPlugin應用於node_modules下的文件。

{ 
    test: /\.(scss|css)$/, 
    exclude: [/node_modules/], // Add this line under your current configs 
    use: ExtractTextPlugin.extract({ 
    fallback: 'style-loader', 
    use: [ 
     'css-loader', 
     'sass-loader', 
    ] 
    }) 
}, 

// Add a new rule for those under node_modules 
{ 
    test: /\.(scss|css)$/, 
    include: [/node_modules/], 
    loaders: [ 
    'style-loader', 
    'css-loader', 
    'sass-loader', 
    ] 
} 
+0

我曾試過,但沒有區別。我仍然得到這些CSS文件。無論如何,我現在可以,我只是在我的HTML文件中包括這些。 – Mah3ndra

+0

更新了答案。如果你仍然想實現這個目標,那就試試吧。試過在我自己的環境中,工作正常。 (當我測試這個時,供應商的CSS文件在main塊中是必需的) –