gpt4 book ai didi

webpack - 如何将每个 node_module 捆绑为 webpack 中的单独 bundle ?

转载 作者:行者123 更新时间:2023-12-02 00:15:20 26 4
gpt4 key购买 nike

我有一个 React 项目,我们在其中使用了很多依赖项。我在关注 this hackernoon post其中作者提到如何将每个 node_module 拆分为一个单独的文件,如 npm-package1.js...2.js 等.

如何在我的 webpack 配置中实现它?我一直在尝试修改的当前 webpack 配置:

const prodWebpackConfig = {
entry: { },
optimization: {
runtimeChunk: 'single',
splitChunks: {
cacheGroups: {
vendor: {
test: /[\\/]node_modules[\\/]/,
name: 'vendor',
chunks: 'initial'
}
}
}
}
};

我正在运行这个文件,它总是在我的 dist 中生成应用程序、运行时、样式和 vendor.js。我无法将所有 NPM 包都视为 bundle 。如何实现此配置?

最佳答案

看起来指向作者 Gists 的预期链接无法正常工作,但您仍然可以在 GitHub 上看到它们。这些示例的 webpack.config.js 如下所示:


module.exports = { entry: {
main: path.resolve(__dirname, 'src/index.js'),
ProductList: path.resolve(__dirname, 'src/ProductList/ProductList.js'),
ProductPage: path.resolve(__dirname, 'src/ProductPage/ProductPage.js'),
Icon: path.resolve(__dirname, 'src/Icon/Icon.js'), }, output: {
path: path.resolve(__dirname, 'dist'),
filename: '[name].[contenthash:8].js', }, plugins: [
new webpack.HashedModuleIdsPlugin(), // so that file hashes don't change unexpectedly ], optimization: {
runtimeChunk: 'single',
splitChunks: {
chunks: 'all',
maxInitialRequests: Infinity,
minSize: 0,
cacheGroups: {
vendor: {
test: /[\\/]node_modules[\\/]/,
name(module) {
// get the name. E.g. node_modules/packageName/not/this/part.js
// or node_modules/packageName
const packageName = module.context.match(/[\\/]node_modules[\\/](.*?)([\\/]|$)/)[1];

// npm package names are URL-safe, but some servers don't like @ symbols
return `npm.${packageName.replace('@', '')}`;
},
},
},
},
},
};

来源:https://gist.github.com/davidgilbertson/c9af3e583f95de03439adced007b47f1

关于webpack - 如何将每个 node_module 捆绑为 webpack 中的单独 bundle ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57131221/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com