时间:2021-05-26
optimization总结
minimize
默认为true,效果就是压缩js代码。
minimizer
可以自定义UglifyJsPlugin和一些配置,默认的压缩为uglifyjs-webpack-plugin
//比如在构建的时候,希望新增css的压缩minimizer: mode === "development" ? [] : [ new UglifyJsPlugin({ cache: true, parallel: true, sourceMap: mode === "development" }), new OptimizeCSSAssetsPlugin() ]runtimeChunk
默认为false,runtime相关的代码(各个模块之间的引用和加载的逻辑)内嵌入每个entry。
true:对于每个entry会生成runtime~${entrypoint.name}的文件。
'single': 会生成一个唯一单独的runtime.js文件,就是manifest。
multiple:和true一致。name:{}:自定义runtime文件的name
noEmitOnErrors
默认为true,编译错误的时候是否不生成资源。
namedModules,namedChunks
development默认都为true,production默认为false,选择是否给module和chunk更有意义的名称。
nameModules:true这里会显示路径
nameModules:false直接采用索引自增
namedChunks:true
namedChunks:false采用索引
moduleIds
一般不建议配置namedModules,namedChunks
针对module的配置,这里会取hashed。
针对chunk的配置,特别是异步代码一般会采用@vue-cli3推荐的插件
removeAvailableModules,removeEmptyChunks,mergeDuplicateChunks,flagIncludedChunks
这4个参数构建默认都是true,主要是用于构建优化,不需要改,基本就是字面意思。
splitChunks
主要就是根据不同的策略来分割打包出来的bundle。
默认配置:
1.chunks
async(默认):
splitChunks:{ chunks:'async'//分割异步打包的代码,}打包出b和vue两个chunk。
all:
splitChunks:{ chunks:'all',//同时分割同步和异步代码,推荐。 cacheGroup:{//默认的规则不会打包,需要单独定义 a: { test: /a\.js/, chunks: "all", name: "a", enforce: true } }}initial
splitChunks:{ chunks:'initial'//也会同时打包同步和异步,但是异步内部的引入不再考虑,直接打包在一起,会将vue和b的内容直接打包成chunk, cacheGroup:{//默认的规则不会打包,需要单独定义 a: { test: /a\.js/, chunks: "all", name: "a", enforce: true } }}2.name
分割的js名称,默认为true,返回
${cacheGroup的key} ${automaticNameDelimiter} ${moduleName},可以自定义。
3.minChunks
最小公用模块次数,默认为1
4.minSize,maxSize,maxAsyncRequests(按需加载时候最大的并行请求数),maxInitialRequests(一个入口最大的并行请求数)
都为字面意思,一般不建议改。
5.cacheGroups
缓存策略,默认设置了分割node_modules和公用模块。内部的参数可以和覆盖外部的参数。
test 正则匹配文件
priority 优先级
reuseExistingChunk是否复用存在的chunk
6.automaticNameDelimiter
文件名称分隔符号~
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
好久不看webpack已经从3到4了,其实很早到今年2月份就开始发布webpack4的beta版本;每一次webpack的升级都还是建议阅读下《webpack4
最近使用webpack4配置ssr环境,发现的问题:ReferenceError:documentisnotdefined本次package.json使用版本信
webpack@4.x的变化先来说下webpack4和之前版本里一些主要的变化:1、webpack不再支持nodev4,这是因为新的webpack和附属插件使用
前言最近新起了一个多页项目,之前都未使用webpack4,于是准备上手实践一下。这篇文章主要就是一些配置介绍,对于正准备使用webpack4的同学,可以做一些参
前言:webpack4出了以后,一些插件变化很大,和之前的版本使用方式不一样,新手入坑,本篇将介绍如何从一开始配置webpack4的开发版本,对css,js进行