vue cli升級(jí)webapck4總結(jié)
webpack4 released 已經(jīng)有一段時(shí)間了,插件系統(tǒng)趨于平穩(wěn),適逢對(duì)webpack3的打包速度很不滿意,因此決定將當(dāng)前在做的項(xiàng)目進(jìn)行升級(jí),正好也實(shí)踐一下webpack4。
新特性
0配置
應(yīng)該是parcel出來(lái)以后,webpack團(tuán)隊(duì)意識(shí)到其配置確實(shí)有點(diǎn)復(fù)雜,不太容易上手。so, webapck4 開(kāi)始支持0配置啟動(dòng)。不過(guò),萬(wàn)變不離其宗,webpack4的0配置也只是支持了默認(rèn)entry 和 output而已,即默認(rèn)entry為./src,默認(rèn)output為/dist。
模式選擇mode
mode有兩個(gè)可選項(xiàng),production & development。作為必選項(xiàng),mode是不可缺省的。在production模式下,會(huì)默認(rèn)做一些必要的優(yōu)化,如代碼壓縮和作用域提升,還會(huì)默認(rèn)指定process.env.NODE_ENV 為 production。在development模式下,優(yōu)化了增量構(gòu)建,支持注釋和提示,并且支持 eval 下的 source maps,同時(shí)默認(rèn)指定process.env.NODE_ENV 為 development。
sideEffects
通過(guò)該配置可以大幅度減小打包體積。當(dāng)模塊的 package.json 配置sideEffects:false表明該模塊沒(méi)有副作用,也就意味著 webpack 可以安全地清除被用于重復(fù)導(dǎo)出(re-exports)的代碼。
模塊類型
webpack4提供了5種模塊類型。
- json: 可通過(guò) require 和 import 導(dǎo)入的 JSON 格式的數(shù)據(jù)(默認(rèn)為 .json 的文件)
- webassembly: WebAssembly 模塊,(目前是 .wasm 文件的默認(rèn)類型)
- javascript/auto: (webpack 3中的默認(rèn)類型)支持所有的JS模塊系統(tǒng):CommonJS、AMD。
- javascript/esm: EcmaScript模塊(默認(rèn) .mjs 文件)。
- javascript/dynamic: 僅支持 CommonJS & AMD。
JSON
webpack 4 不僅支持本地處理 JSON,還支持對(duì) JSON 的 Tree Shaking。當(dāng)使用 ESM 語(yǔ)法 import json 時(shí),webpack 會(huì)消除掉JSON Module 中未使用的導(dǎo)出。此外,如果要用 loader 轉(zhuǎn)換 json 為 js,需要設(shè)置 type 為 javascript/auto。
optimization
Webpack 4 刪除了 CommonsChunkPlugin,并默認(rèn)啟用了它的許多功能。因此webpack4可以實(shí)現(xiàn)很好的默認(rèn)優(yōu)化。但是,對(duì)于那些需要自定義的緩存策略,增加了 optimization.splitChunks 和 optimization.runtimeChunk。具體解釋可參考這篇文章,解釋得很詳細(xì)。RIP CommonsChunkPlugin點(diǎn)擊預(yù)覽
。
手把手升級(jí)
我是把原來(lái)vue cli的項(xiàng)目做了一下升級(jí),總體來(lái)說(shuō),升級(jí)還算是比較順利步驟,這里我們分成兩步走,首先升級(jí)相關(guān)依賴的插件,然后優(yōu)化webapck配置文件。
升級(jí)插件
首先要把下面列表的插件升級(jí)到對(duì)應(yīng)版本或者最新版本
webpack@4.4.1
css-loader@0.28.10,
extract-text-webpack-plugin@4.0.0-beta.0,
file-loader@1.1.11,
html-webpack-plugin@3.1.0,
optimize-css-assets-webpack-plugin@4.0.0,
url-loader@1.0.1,
vue-loader@14.2.2,
vue-style-loader@4.1.0,
vue-template-compiler@2.5.16,
webpack-bundle-analyzer@2.11.1,
webpack-dev-middleware@3.1.0,
webpack-dev-server@3.1.1,
webpack-hot-middleware@2.21.2
如果遇到其他包報(bào)錯(cuò),應(yīng)該是升級(jí)到最新的就可以解決了。
更新配置文件
webpack.dev.conf.js
dev環(huán)境變化不大,畢竟webpack4很大一部分的優(yōu)化都是針對(duì)生產(chǎn)環(huán)境的,該文件我們只需要?jiǎng)h除一些不再需要的插件既可以。例如:webpack.NamedModulesPlugin、webpack.NoEmitOnErrorsPlugin,其功能webpack4已經(jīng)默認(rèn)配置。同時(shí),要設(shè)置
mode: 'development'
webpack.production.conf.js
webvpack4中改動(dòng)最大,影響也最大的就是webpack4使用optimization.splitChunks替代了CommonsChunkPlugin。以前的CommonsChunkPlugin主要用來(lái)抽取代碼中的共用部分,webpack runtime之類的代碼,結(jié)合chunkhash,實(shí)現(xiàn)最好的緩存策略。而optimization.splitChunks則實(shí)現(xiàn)了相同的功能,并且配置更加靈活,具體解釋可參考這篇文章,解釋得很詳細(xì)。
mode: 'production',
optimization: {
splitChunks: {
cacheGroups: {
vendors: {
test: /[\\/]node_modules[\\/]/,
chunks: 'initial',
name: 'vendors',
},
'async-vendors': {
test: /[\\/]node_modules[\\/]/,
minChunks: 2,
chunks: 'async',
name: 'async-vendors'
}
}
},
runtimeChunk: { name: 'runtime' }
}
總結(jié)
總體來(lái)說(shuō)本次升級(jí)還算順利,不到一天搞定,目前感覺(jué),打包速度大約優(yōu)化了70%左右,同時(shí)打包后的代碼體積也有了很大的優(yōu)化,帶來(lái)的效果很顯著的。
相關(guān)文章
vue 自動(dòng)生成swagger接口請(qǐng)求文件的方法
這篇文章主要介紹了vue 自動(dòng)生成swagger接口請(qǐng)求文件的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01
Vue關(guān)鍵字搜索功能實(shí)戰(zhàn)小案例
在vue項(xiàng)目中,搜索功能是我們經(jīng)常需要使用的一個(gè)場(chǎng)景,下面這篇文章主要給大家介紹了關(guān)于Vue關(guān)鍵字搜索功能的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
vue將對(duì)象新增的屬性添加到檢測(cè)序列的方法
下面小編就為大家分享一篇vue將對(duì)象新增的屬性添加到檢測(cè)序列的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-02-02
Vue動(dòng)態(tài)組件component標(biāo)簽的用法大全
這篇文章主要介紹了Vue動(dòng)態(tài)組件component標(biāo)簽的用法,在Vue中,可以通過(guò)component標(biāo)簽的is屬性動(dòng)態(tài)指定標(biāo)簽,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
VueJs中的shallowRef與shallowReactive函數(shù)使用比較
這篇文章主要為大家介紹了VueJs中的shallowRef與shallowReactive函數(shù)的使用比較解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
Vue3新特性Suspense和Teleport應(yīng)用場(chǎng)景分析
本文介紹了Vue2和Vue3中的Suspense用于處理異步請(qǐng)求的加載提示,以及如何在組件間實(shí)現(xiàn)動(dòng)態(tài)加載,同時(shí),Teleport技術(shù)展示了如何在DOM中靈活地控制組件的渲染位置,解決布局問(wèn)題,感興趣的朋友跟隨小編一起看看吧2024-07-07
vue3使用vue-count-to組件的實(shí)現(xiàn)
這篇文章主要介紹了vue3使用vue-count-to組件的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
解決Antd 里面的select 選擇框聯(lián)動(dòng)觸發(fā)的問(wèn)題
這篇文章主要介紹了解決Antd 里面的select 選擇框聯(lián)動(dòng)觸發(fā)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10

