前端項目日益復(fù)雜,構(gòu)建系統(tǒng)已經(jīng)成為開發(fā)過程中不可或缺的一個部分,而模塊打包(module bundler)正是前端構(gòu)建系統(tǒng)的核心。Webpack作為當下最受歡迎的前端資源模塊化管理和打包工具,它可以將許多松散的模塊按照依賴和規(guī)則打包成符合生產(chǎn)環(huán)境部署的前端資源。還可以將按需加載的模塊進行代碼分隔,等到實際需要的時候再異步加載。
4.0又發(fā)布了一陣子了,較之前有大量的性能提升,零配置,健全的默認設(shè)置。就讓我們來看看吧!
1、零配置
創(chuàng)新互聯(lián)建站堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的含山網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
官方不再支持node4以下版本,在使用webpack >=4.0前要先安裝webpack-cli
執(zhí)行webpack,會報一個警告,一個錯誤。
4.0之前使用webpack都需要提供一個webpack.config.js的配置文件,并且需要指定entry入口,和output打包之后的文件,而在webpack4.0以上的版本中,webpack4會默認嘗試在./src中尋找index.js入口文件,因此在項目下新建src/index.js,同樣output則默認為./dist/main.js。
2、mode模式的開發(fā)與生產(chǎn)環(huán)境
在webpack4之前,我們配置開發(fā)與生產(chǎn)環(huán)境需要創(chuàng)建兩個配置文件。
在development中通常要配置像webpack-dev-server等一些調(diào)試所用的插件及相關(guān)依賴庫,
在production中通常要配置UglifyJSPlugin等依賴庫。
所以有了前面的警告,
在package.json中修改一下scripts:
執(zhí)行npm run build,
這個 --mode production 主要做了哪些事情呢?主要有hoisting, tree-shaking, minification, scope等等。對應(yīng)的 –mode development 則主要是優(yōu)化編譯速度,輸出一個沒有壓縮的文件。
新建項目我們并沒有手動配置任何東西,webpack4全都為我們解決了。
3.Babel配置
雖然ES6早就出來很久了,但總有些瀏覽器還不能完全支持新的語法及API,Babel則可以把ES6轉(zhuǎn)化為ES5,讓老的瀏覽器識別。
安裝Babel相關(guān)依賴包。
Webpack4的零配置只是讓你不用定義entry和output。
所以如果你的項目比較大,還是老老實實建個webpack.config.js文件吧,
Babel配置
然后在根目錄新建.babelrc文件,配置如下。
接下來運行npm run build,瀏覽器就支持ES6啦。
4、再見commonchunk,你好optimization
從webpack4開始官方移除了commonchunk插件,改用了optimization屬性進行更加靈活的配置,commonchunk配置項被徹底去掉,optimization.minimize為true,代替了webpack.optimize.UglifyJsPlugin。runtimeChunk可以配置成true,single或者對象,用自動計算當前構(gòu)建的一些基礎(chǔ)chunk信息。
Css模塊使用mini-css-extract-plugin代替extract-text-webpack-plugin
因為webpack4發(fā)布時間還不常,大多依賴架包建議升級到最新版本,防止陷坑。以上便是我對webpack4升級的一點建議,歡迎指正!
本文題目:手把手教你升級到Webpack4
轉(zhuǎn)載注明:http://www.rwnh.cn/article22/gdipjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、網(wǎng)站設(shè)計、做網(wǎng)站、動態(tài)網(wǎng)站、網(wǎng)頁設(shè)計公司、網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)