optimization怎么在webpack4中使用

今天就跟大家聊聊有关optimization怎么在webpack4中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

optimization总结

minimize

默认为true,效果就是压缩js代码。

minimizer

可以自定义UglifyJsPlugin和一些配置,默认的压缩为uglifyjs-webpack-plugin

//比如在构建的时候,希望新增css的压缩
minimizer:
mode==="development"
?[]
:[
newUglifyJsPlugin({
cache:true,
parallel:true,
sourceMap:mode==="development"
}),
newOptimizeCSSAssetsPlugin()
]

runtimeChunk

默认为false,runtime相关的代码(各个模块之间的引用和加载的逻辑)内嵌入每个entry

true:对于每个entry会生成runtime~${entrypoint.name}的文件。

optimization怎么在webpack4中使用

'single': 会生成一个唯一单独的runtime.js文件,就是manifest

optimization怎么在webpack4中使用

multiple:和true一致。name:{}:自定义runtime文件的name

optimization怎么在webpack4中使用

optimization怎么在webpack4中使用

noEmitOnErrors

默认为true,编译错误的时候是否不生成资源。

namedModules,namedChunks

development默认都为true,production默认为false,选择是否给modulechunk更有意义的名称。

nameModules:true这里会显示路径

optimization怎么在webpack4中使用

nameModules:false直接采用索引自增

optimization怎么在webpack4中使用

namedChunks:true

optimization怎么在webpack4中使用

namedChunks:false采用索引

optimization怎么在webpack4中使用

moduleIds

一般不建议配置namedModules,namedChunks针对module的配置,这里会取hashed

optimization怎么在webpack4中使用

针对chunk的配置,特别是异步代码一般会采用@vue-cli3推荐的插件

optimization怎么在webpack4中使用

removeAvailableModules,removeEmptyChunks,mergeDuplicateChunks,flagIncludedChunks

这4个参数构建默认都是true,主要是用于构建优化,不需要改,基本就是字面意思。

splitChunks

主要就是根据不同的策略来分割打包出来的bundle。默认配置:

optimization怎么在webpack4中使用

1.chunks

optimization怎么在webpack4中使用

async(默认)

splitChunks:{
chunks:'async'//分割异步打包的代码,
}

打包出b和vue两个chunk。

optimization怎么在webpack4中使用

all:

splitChunks:{
chunks:'all',//同时分割同步和异步代码,推荐。
cacheGroup:{//默认的规则不会打包,需要单独定义
a:{
test:/a\.js/,
chunks:"all",
name:"a",
enforce:true
}
}
}

optimization怎么在webpack4中使用

initial

splitChunks:{
chunks:'initial'//也会同时打包同步和异步,但是异步内部的引入不再考虑,直接打包在一起,会将vue和b的内容直接打包成chunk,
cacheGroup:{//默认的规则不会打包,需要单独定义
a:{
test:/a\.js/,
chunks:"all",
name:"a",
enforce:true
}
}
}

optimization怎么在webpack4中使用

2.name分割的js名称,默认为true,返回${cacheGroup的key} ${automaticNameDelimiter} ${moduleName},可以自定义。

3.minChunks最小公用模块次数,默认为1

4.minSize,maxSize,maxAsyncRequests(按需加载时候最大的并行请求数),maxInitialRequests(一个入口最大的并行请求数)都为字面意思,一般不建议改。

5.cacheGroups缓存策略,默认设置了分割node_modules和公用模块。内部的参数可以和覆盖外部的参数。test 正则匹配文件priority 优先级reuseExistingChunk是否复用存在的chunk

cacheGroup:{
a:{
test:/a\.js/,//匹配规则
minChunks:2,//重写公用chunks的次数
chunks:"all",
name:"a",//重写文件名称
enforce:true//强制生成
}
}

看完上述内容,你们对optimization怎么在webpack4中使用有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注恰卡编程网行业资讯频道,感谢大家的支持。

发布于 2021-03-24 01:22:04
收藏
分享
海报
0 条评论
179
上一篇:使用django和vue怎么实现数据交互 下一篇:怎么在Python中使用random.shuffle()函数打乱列表顺序
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码