//webpack.config.js -- shortened for convenience
const
ExtractTextPlugin = require("extract-text-webpack-plugin"),
extractSass = new ExtractTextPlugin({
filename: "Css/[name].css",
allChunks: true
}),
//…
config: {
module: {
rules: [
//…
{
test: /\.scss$/,
use: extractSass.extract([ 'css-loader', 'sass-loader' ])
}
//…
]
},
plugins: [
extractSass
]
}
module.exports = config;
使用时:
0% compiling(node:333) DeprecationWarning: Tapable.plugin is deprecated. Use new API on `.hooks` instead
(node:333) DeprecationWarning: Tapable.apply is deprecated. Call apply on the plugin directly instead
77% module and chunk tree optimization unnamed compat plugin/xxx/node_modules/webpack/lib/Chunk.js:460
throw new Error(
^
Error: Chunk.entrypoints: Use Chunks.groupsIterable and filter by instanceof Entrypoint instead
at Chunk.get (/xxx/node_modules/webpack/lib/Chunk.js:460:9)
at /xxx/node_modules/extract-text-webpack-plugin/dist/index.js:176:48
at Array.forEach (<anonymous>)
at /xxx/node_modules/extract-text-webpack-plugin/dist/index.js:171:18
at AsyncSeriesHook.eval [as callAsync] (eval at create (/xxx/node_modules/tapable/lib/HookCodeFactory.js:24:12), <anonymous>:12:1)
at AsyncSeriesHook.lazyCompileHook [as _callAsync] (/xxx/node_modules/tapable/lib/Hook.js:35:21)
at Compilation.seal (/xxx/node_modules/webpack/lib/Compilation.js:881:27)
at hooks.make.callAsync.err (/xxx/node_modules/webpack/lib/Compiler.js:464:17)
at _err0 (eval at create (/xxx/node_modules/tapable/lib/HookCodeFactory.js:24:12), <anonymous>:11:1)
at _addModuleChain (/xxx/node_modules/webpack/lib/Compilation.js:749:12)
at processModuleDependencies.err (/xxx/node_modules/webpack/lib/Compilation.js:688:9)
at process._tickCallback (internal/process/next_tick.js:150:11)
该设置一直有效,直到webpack v4。禁用插件会使错误消失。我发现webpacks插件系统已经改变,但我无法弄清楚如何解决这个错误。
答案 0 :(得分:42)
正如here所述,问题在于extract-text-webpack-plugin
需要升级才能使用webpack v4
。所以:
npm install extract-text-webpack-plugin@next
肯定会解决问题。
答案 1 :(得分:6)
Webpack v4似乎不建议使用extract-text-webpack-plugin。参见README,其中说:
⚠️从webpack v4开始,extract-text-webpack-plugin不应用于CSS。请改用mini-css-extract-plugin。
本期The Future of this Plugin vs. Mini CSS Extract Plugin提供了有关弃用的更多信息。
答案 2 :(得分:0)
使用此版本“ extract-text-webpack-plugin”:“ ^ 4.0.0-beta.0”,