国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

            手機(jī)站
            千鋒教育

            千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

            千鋒教育

            掃一掃進(jìn)入千鋒手機(jī)站

            領(lǐng)取全套視頻
            千鋒教育

            關(guān)注千鋒學(xué)習(xí)站小程序
            隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

            當(dāng)前位置:首頁  >  技術(shù)干貨  > 如何減少 Webpack 打包體積

            如何減少 Webpack 打包體積

            來源:千鋒教育
            發(fā)布人:wjy
            時(shí)間: 2022-09-07 16:58:00 1662541080

              1. 按需加載

              在開發(fā) SPA 項(xiàng)目的時(shí)候,項(xiàng)目中都會存在很多路由頁面。如果將這些頁面全部打包進(jìn)一個(gè) JS 文件的話,雖然將多個(gè)請求合并了,但是同樣也加載了很多并不需要的代碼,耗費(fèi)了更長的時(shí)間。那么為了首頁能更快地呈現(xiàn)給用戶,希望首頁能加載的文件體積越小越好,這時(shí)候就可以使用按需加載,將每個(gè)路由頁面單獨(dú)打包為一個(gè)文件。當(dāng)然不僅僅路由可以按需加載,對于 loadash 這種大型類庫同樣可以使用這個(gè)功能。

              按需加載的代碼實(shí)現(xiàn)這里就不詳細(xì)展開了,因?yàn)殍b于用的框架不同,實(shí)現(xiàn)起來都是不一樣的。當(dāng)然了,雖然他們的用法可能不同,但是底層的機(jī)制都是一樣的。都是當(dāng)使用的時(shí)候再去下載對應(yīng)文件,返回一個(gè) Promise,當(dāng) Promise 成功以后去執(zhí)行回調(diào)。

              2. Scope Hoisting

              Scope Hoisting 會分析出模塊之間的依賴關(guān)系,盡可能的把打包出來的模塊合并到一個(gè)函數(shù)中去。

              比如希望打包兩個(gè)文件:

              

             

              對于這種情況,打包出來的代碼會類似這樣:

              

             

              但是如果使用 Scope Hoisting ,代碼就會盡可能的合并到一個(gè)函數(shù)中去,也就變成了這樣的類似代碼:

              

             

              這樣的打包方式生成的代碼明顯比之前的少多了。如果在 Webpack4 中你希望開啟這個(gè)功能,只需要啟用 optimization.concatenateModules 就可以了:

              

             

              3. Tree Shaking

              Tree Shaking 可以實(shí)現(xiàn)刪除項(xiàng)目中未被引用的代碼,比如:

              

             

              對于以上情況,test 文件中的變量 b 如果沒有在項(xiàng)目中使用到的話,就不會被打包到文件中。

              如果使用 Webpack 4 的話,開啟生產(chǎn)環(huán)境就會自動啟動這個(gè)優(yōu)化功能。

            tags:
            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
            免費(fèi)領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學(xué) 138****2860 剛剛成功領(lǐng)取
            王同學(xué) 131****2015 剛剛成功領(lǐng)取
            張同學(xué) 133****4652 剛剛成功領(lǐng)取
            李同學(xué) 135****8607 剛剛成功領(lǐng)取
            楊同學(xué) 132****5667 剛剛成功領(lǐng)取
            岳同學(xué) 134****6652 剛剛成功領(lǐng)取
            梁同學(xué) 157****2950 剛剛成功領(lǐng)取
            劉同學(xué) 189****1015 剛剛成功領(lǐng)取
            張同學(xué) 155****4678 剛剛成功領(lǐng)取
            鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
            董同學(xué) 138****2867 剛剛成功領(lǐng)取
            周同學(xué) 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT
            軟件定制開發(fā)中的敏捷開發(fā)是什么?

            軟件定制開發(fā)中的敏捷開發(fā)是什么軟件定制開發(fā)中的敏捷開發(fā),從宏觀上看,是一個(gè)高度關(guān)注人員交互,持續(xù)開發(fā)與交付,接受需求變更并適應(yīng)環(huán)境變化...詳情>>

            2023-10-14 13:24:57
            什么是PlatformIo?

            PlatformIO是什么PlatformIO是一個(gè)全面的物聯(lián)網(wǎng)開發(fā)平臺,它為眾多硬件平臺和開發(fā)環(huán)境提供了統(tǒng)一的工作流程,有效簡化了開發(fā)過程,并能兼容各種...詳情>>

            2023-10-14 12:55:06
            云快照與自動備份有什么區(qū)別?

            1、定義和目標(biāo)不同云快照的主要目標(biāo)是提供一種快速恢復(fù)數(shù)據(jù)的方法,它只記錄在快照時(shí)間點(diǎn)后的數(shù)據(jù)變化,而不是所有的數(shù)據(jù)。自動備份的主要目標(biāo)...詳情>>

            2023-10-14 12:48:59
            服務(wù)器為什么要用Linux?

            服務(wù)器為什么要用Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,Linux在眾多選擇中脫穎而出。Linux作為服務(wù)器操作系統(tǒng)的優(yōu)選,有其獨(dú)特的優(yōu)勢和特點(diǎn)。包括其...詳情>>

            2023-10-14 12:34:11
            ORM解決的主要問題是什么?

            ORM(對象關(guān)系映射)解決的主要問題是將關(guān)系數(shù)據(jù)庫與面向?qū)ο缶幊讨g的映射困境。在傳統(tǒng)的關(guān)系數(shù)據(jù)庫中,數(shù)據(jù)以表格的形式存儲,而在面向?qū)ο?..詳情>>

            2023-10-14 12:26:19
            快速通道