webpack3插件CommonChunkPlugin分离vantUI和echarts,问题的webpackJsonp is not defined解决!!!

webpack3插件CommonChunkPlugin分离vantUI和echarts和报错webpackJsonp is not defined的解决

前景:因为项目使用的webpack3开发的场景,打包后的vendor很大,如图显示


如果不做gzip处理的话,大小在2M多,gzip后的大小是600KB,但是考虑里面还包括各种公共包,所以对vendor文件再拆分处理;

默认打包的代码如下:

javascript 复制代码
webpack.prod.conf.js 默认配置如下:

new webpack.optimize.CommonsChunkPlugin({
  name: 'vendor',
  minChunks(module) {
     return module.resource && 
     	/\\.js$/.test(module.resource) &&
     	module.resource.indexOf(path.join(__dirname, '../node\_modules')) ===0
     }
}),
new webpack.optimize.CommonsChunkPlugin({
    name: 'manifest',
    minChunks: Infinity
})
new webpack.optimize.CommonsChunkPlugin({
    name: 'app',
    async: 'vendor-async',
    children: true,
    minChunks: 2
})

修改webpack.prod.conf.js 配置如下:

javascript 复制代码
new HtmlWebpackPlugin({
       filename: config.build.index,
       template: 'index.html',
       inject: true,
       minify: {
           removeComments: true,
           collapseWhitespace: true,
           removeAttributeQuotes: true
        },
      chunks: ['manifest', 'vendor', 'vendor_echarts', 'vendor_vantUI', 'app'], // 更改此行配置,按照依赖关系从左至右书写
      chunksSortMode: 'manual' //更改此行配置,上面的配置无效的原因就是配置了非此值
 })

newwebpack.optimize.CommonsChunkPlugin({
  name: 'vendor',
  minChunks(module) {
     return module.resource && 
     	/\\.js$/.test(module.resource) &&
     	module.resource.indexOf(path.join(__dirname, '../node\_modules')) ===0
     }
}),
new webpack.optimize.CommonsChunkPlugin({
    name: 'vendor_echarts',
    chunks: ['vendor'],
    minChunks(module) {
        return module.resource && /vant/.test(module.resource)
    }
}) 
new webpack.optimize.CommonsChunkPlugin({
    name: 'vendor_vantUI',
    chunks: ['vendor'],
    minChunks(module) {
        return module.resource && /echarts/.test(module.resource)
    }
})
new webpack.optimize.CommonsChunkPlugin({
    name: 'manifest',
    chunks: ['vendor', 'vendor_echarts', 'vendor_vantUI', 'app'],
    minChunks: Infinity
})
new webpack.optimize.CommonsChunkPlugin({
    name: 'app',
    async: 'vendor-async',
    children: true,
    minChunks: 2
})



注意要和上面配置一样才行,不然后续会报错这个问题 !!!
webpackJsonp is not defined !!!


最终打包后效果如下图:


最后项目运行在生产没问题!!!

非常感谢这个大佬的处理,也是按照他的方案搞定的,感谢!

webpack3插件CommonChunkPlugin分离ElementUI和Echarts

相关推荐
阿正的梦工坊5 分钟前
JavaScript 闭包 × C++ 类比:彻底搞懂闭包
开发语言·javascript·c++
smilejingwei22 分钟前
用 AI 编程生成 ECharts 图表并嵌入报表的实践
前端·人工智能·echarts·bi·报表工具·商业智能
Linux运维技术栈44 分钟前
Cloudflare Argo Smart Routing全球加速:优化跨境回源链路,提升跨区域访问体验
大数据·前端·数据库
恋猫de小郭1 小时前
Android CLI ,谷歌为 Android 开发者专研的 AI Agent,提速三倍
android·前端·flutter
Hello--_--World1 小时前
Js 隐式类型转换、JavaScript `==` vs `===` 深度对比表
开发语言·javascript·ecmascript
freewlt1 小时前
从 0 搭建现代前端组件库:2026年完整实战指南
前端
凌冰_1 小时前
Thymeleaf 核心语法详解
java·前端·javascript
AIBox3651 小时前
claude 镜像 api 使用指南(2026 年4 月更新)
java·服务器·前端·人工智能·gpt·前端框架
SuperEugene2 小时前
Vue3 配置文件管理:按模块拆分配置,提升配置可维护性|配置驱动开发实战篇
前端·javascript·vue.js·驱动开发
阿凤212 小时前
后端返回文件二进制流
开发语言·前端·javascript·uniapp