欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue cli升級webapck4總結

 更新時間:2018年04月04日 08:47:59   作者:wupengyu  
這篇文章主要介紹了vue cli升級webapck4的步驟以及需要注意的地方,大家可以跟著操作學習下。

webpack4 released 已經(jīng)有一段時間了,插件系統(tǒng)趨于平穩(wěn),適逢對webpack3的打包速度很不滿意,因此決定將當前在做的項目進行升級,正好也實踐一下webpack4。

新特性

0配置

應該是parcel出來以后,webpack團隊意識到其配置確實有點復雜,不太容易上手。so, webapck4 開始支持0配置啟動。不過,萬變不離其宗,webpack4的0配置也只是支持了默認entry 和 output而已,即默認entry為./src,默認output為/dist。

模式選擇mode

mode有兩個可選項,production & development。作為必選項,mode是不可缺省的。在production模式下,會默認做一些必要的優(yōu)化,如代碼壓縮和作用域提升,還會默認指定process.env.NODE_ENV 為 production。在development模式下,優(yōu)化了增量構建,支持注釋和提示,并且支持 eval 下的 source maps,同時默認指定process.env.NODE_ENV 為 development。

sideEffects

通過該配置可以大幅度減小打包體積。當模塊的 package.json 配置sideEffects:false表明該模塊沒有副作用,也就意味著 webpack 可以安全地清除被用于重復導出(re-exports)的代碼。

模塊類型

webpack4提供了5種模塊類型。

  1. json: 可通過 require 和 import 導入的 JSON 格式的數(shù)據(jù)(默認為 .json 的文件)
  2. webassembly: WebAssembly 模塊,(目前是 .wasm 文件的默認類型)
  3. javascript/auto: (webpack 3中的默認類型)支持所有的JS模塊系統(tǒng):CommonJS、AMD。
  4. javascript/esm: EcmaScript模塊(默認 .mjs 文件)。
  5. javascript/dynamic: 僅支持 CommonJS & AMD。

JSON

webpack 4 不僅支持本地處理 JSON,還支持對 JSON 的 Tree Shaking。當使用 ESM 語法 import json 時,webpack 會消除掉JSON Module 中未使用的導出。此外,如果要用 loader 轉換 json 為 js,需要設置 type 為 javascript/auto。

optimization

Webpack 4 刪除了 CommonsChunkPlugin,并默認啟用了它的許多功能。因此webpack4可以實現(xiàn)很好的默認優(yōu)化。但是,對于那些需要自定義的緩存策略,增加了 optimization.splitChunks 和 optimization.runtimeChunk。具體解釋可參考這篇文章,解釋得很詳細。RIP CommonsChunkPlugin點擊預覽
。

手把手升級

我是把原來vue cli的項目做了一下升級,總體來說,升級還算是比較順利步驟,這里我們分成兩步走,首先升級相關依賴的插件,然后優(yōu)化webapck配置文件。

升級插件

首先要把下面列表的插件升級到對應版本或者最新版本

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

如果遇到其他包報錯,應該是升級到最新的就可以解決了。

更新配置文件

webpack.dev.conf.js

dev環(huán)境變化不大,畢竟webpack4很大一部分的優(yōu)化都是針對生產(chǎn)環(huán)境的,該文件我們只需要刪除一些不再需要的插件既可以。例如:webpack.NamedModulesPlugin、webpack.NoEmitOnErrorsPlugin,其功能webpack4已經(jīng)默認配置。同時,要設置

mode: 'development'
webpack.production.conf.js

webvpack4中改動最大,影響也最大的就是webpack4使用optimization.splitChunks替代了CommonsChunkPlugin。以前的CommonsChunkPlugin主要用來抽取代碼中的共用部分,webpack runtime之類的代碼,結合chunkhash,實現(xiàn)最好的緩存策略。而optimization.splitChunks則實現(xiàn)了相同的功能,并且配置更加靈活,具體解釋可參考這篇文章,解釋得很詳細。

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' }
}

總結

總體來說本次升級還算順利,不到一天搞定,目前感覺,打包速度大約優(yōu)化了70%左右,同時打包后的代碼體積也有了很大的優(yōu)化,帶來的效果很顯著的。

相關文章

  • vue項目的html如何引進public里面的js文件

    vue項目的html如何引進public里面的js文件

    這篇文章主要介紹了vue項目的html如何引進public里面的js文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue前端項目打包成Docker鏡像并運行的實現(xiàn)

    vue前端項目打包成Docker鏡像并運行的實現(xiàn)

    這篇文章主要介紹了vue前端項目打包成Docker鏡像并運行的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue使用Echarts實現(xiàn)數(shù)據(jù)可視化的方法詳解

    Vue使用Echarts實現(xiàn)數(shù)據(jù)可視化的方法詳解

    這篇文章主要為大家詳細介紹了Vue使用Echarts實現(xiàn)數(shù)據(jù)可視化的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • Vue中實現(xiàn)回車鍵切換焦點的方法

    Vue中實現(xiàn)回車鍵切換焦點的方法

    這篇文章主要介紹了在Vue中實現(xiàn)回車鍵切換焦點的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • Vue-Router進階之滾動行為詳解

    Vue-Router進階之滾動行為詳解

    本篇文章主要介紹了Vue-Router進階之滾動行為詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • 手把手搭建安裝基于windows的Vue.js運行環(huán)境

    手把手搭建安裝基于windows的Vue.js運行環(huán)境

    手把手教大家搭建安裝基于windows的Vue.js的運行環(huán)境,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Vue使用Element實現(xiàn)增刪改查+打包的步驟

    Vue使用Element實現(xiàn)增刪改查+打包的步驟

    這篇文章主要介紹了Vue使用Element實現(xiàn)增刪改查+打包的步驟,幫助大家更好的理解和學習vue框架,感興趣的朋友可以了解下
    2020-11-11
  • vue3 element-plus el-tree自定義圖標方式

    vue3 element-plus el-tree自定義圖標方式

    這篇文章主要介紹了vue3 element-plus el-tree自定義圖標方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue.js手風琴菜單組件開發(fā)實例

    Vue.js手風琴菜單組件開發(fā)實例

    這篇文章主要為大家詳細介紹了Vue.js手風琴菜單組件開發(fā)實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • vue實現(xiàn)div高度可拖拽

    vue實現(xiàn)div高度可拖拽

    這篇文章主要為大家詳細介紹了vue實現(xiàn)div高度可拖拽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10

最新評論