亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vite性能優(yōu)化之分包策略的實(shí)現(xiàn)

 更新時(shí)間:2023年05月08日 14:29:33   作者:拾荒草  
本文主要介紹了Vite性能優(yōu)化之分包策略的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

為什么需要分包策略?

還是舉個(gè)例子,來回憶一下吧,什么呢?
比如說,我使用了 loadsh.js 的東西,那么我們?cè)诖虬臅r(shí)候,就會(huì)把 loadsh 相關(guān)資源也會(huì)打包進(jìn)來,這個(gè)是沒有問題的,此時(shí)是將 loadsh 的東西 與 我們自己寫的相關(guān)代碼合成一個(gè)文件,記住是一個(gè)文件。
瀏覽器是有緩存機(jī)制的,當(dāng)每一次去請(qǐng)求的文件資源時(shí) ( 文件名是沒有發(fā)生改變的時(shí)候,就會(huì)讀取內(nèi)存中的數(shù)據(jù),而不會(huì)重新去服務(wù)器獲取 )。
分包,我的理解,就是將第三方資源文件單獨(dú)打成一個(gè)文件,自己寫的代碼打成另一個(gè)文件

如果我們不進(jìn)行分包
我們每一次修改代碼之后,進(jìn)行打包,結(jié)果這個(gè)文件的內(nèi)容有 :第三方資源包代碼 + 我們自己寫的業(yè)務(wù)代碼。
而且,這個(gè)文件的名字,每一次都會(huì)發(fā)生變化的(源代碼發(fā)生變化),所以當(dāng)用戶去訪問我們的頁面時(shí),請(qǐng)求的資源文件內(nèi)容有 : 第三方資源包代碼 + 自己的業(yè)務(wù)代碼,而真正需要跟新的只有 自己的業(yè)務(wù)代碼,導(dǎo)致每一次,請(qǐng)求的js文件體積都很大,所以響應(yīng)時(shí)間會(huì)長(zhǎng)一些

瀏覽器的緩存策略

瀏覽器在請(qǐng)求靜態(tài)資源時(shí),只要靜態(tài)資源的名稱不變,它就不會(huì)重新請(qǐng)求 xxx.js資源。

使用Vite打包后的js文件是帶有哈希值的,只要我們的代碼內(nèi)容有一點(diǎn)點(diǎn)變化,那么文件的hash值都會(huì)變化。

我們初始化一個(gè)項(xiàng)目,安裝vite進(jìn)行演示

npm init -y
npm i vite -D
// main.js中寫一點(diǎn)邏輯
const mainArr = []

打包

更改main.js中的邏輯然后重新打包

// 更改main.js中的邏輯
let mainArr = []

可見,項(xiàng)目中任何業(yè)務(wù)代碼更改后,文件的hash值都會(huì)改變,重新部署代碼后,瀏覽器都會(huì)重新請(qǐng)求資源文件。

基于這種策略,服務(wù)器往往存在不必要的性能浪費(fèi)。

瀏覽器緩存策略的不足

假設(shè)我們的項(xiàng)目修改了一點(diǎn)點(diǎn)業(yè)務(wù)邏輯,每次 打包發(fā)布后,由于打包的文件名發(fā)生了改變,瀏覽器都會(huì)重新請(qǐng)求這個(gè)js文件。

看個(gè)示例:

我們引入lodash,然后main.js中寫入一點(diǎn)邏輯。

import { forEach } from "lodash"
const mainArr = []
forEach(mainArr,(ele) => {
  console.log('ele: ', ele);
})

打包

main.js中修改了一點(diǎn)點(diǎn)內(nèi)容,重新打包

注:為了展示源碼,這里關(guān)閉了打包時(shí)的代碼壓縮。vite.config.js中配置build:{minify:false}

通過這個(gè)示例我們可以發(fā)現(xiàn)個(gè)問題,我們引入了lodash,雖然它的內(nèi)容始終沒有變(大概有5481行的代碼),但是隨著業(yè)務(wù)代碼的一點(diǎn)點(diǎn)修改,它都會(huì)和業(yè)務(wù)代碼打包在一起,被瀏覽器重新請(qǐng)求。

這是浪費(fèi)性能的,lodash完全沒有必要被重新請(qǐng)求。如果我們將lodash和業(yè)務(wù)代碼打包成兩個(gè)獨(dú)立的js文件,就可以完美解決這個(gè)問題。這就是分包策略。

分包策略就是把一些不會(huì)經(jīng)常更新的文件,進(jìn)行單獨(dú)打包處理。

分包策略的實(shí)現(xiàn)

vite中實(shí)現(xiàn)分包策略,實(shí)際是靠配置rollup的打包配置完成的。

// vite.config.js
import { defineConfig } from "vite";
export default defineConfig({
  build:{
    // 在這里配置打包時(shí)的rollup配置
    rollupOptions:{
    }
  }
});

rollup的output.manualChunks這一配置可以實(shí)現(xiàn)分包策略,具體內(nèi)容可以查看官網(wǎng):

https://www.rollupjs.com/guide/big-list-of-options

output.manualChunks

官方注解:

當(dāng)該選項(xiàng)值為函數(shù)形式時(shí),每個(gè)被解析的模塊都會(huì)經(jīng)過該函數(shù)處理。如果函數(shù)返回字符串,那么該模塊及其所有依賴將被添加到以返回字符串命名的自定義 chunk 中。例如,以下例子會(huì)創(chuàng)建一個(gè)命名為 vendor 的 chunk,它包含所有在 node_modules 中的依賴。

manualChunks(id) {
  if (id.includes('node_modules')) {
    return 'vendor';
  }
}

我們打印一下manualChunks函數(shù)的參數(shù)

import { defineConfig } from "vite";
export default defineConfig({
  build:{
    minify:false,
    // 在這里配置打包時(shí)的rollup配置
    rollupOptions:{
      manualChunks:(id) => {
        console.log("id-------------",id);
      }
    }
  }
});

可以看出,id對(duì)應(yīng)的就是所有需要打包整合的文件,如果id包含node_modules,一定不是我們的業(yè)務(wù)代碼,根據(jù)官方釋義,我們可以將包含node_modules的文件打包在一起

import { defineConfig } from "vite";
export default defineConfig({
  build:{
    minify:false,
    // 在這里配置打包時(shí)的rollup配置
    rollupOptions:{
      manualChunks:(id) => {
        if (id.includes('node_modules')) {
          return 'vendor';
        }
      }
    }
  }
});

重新打包后,可以發(fā)現(xiàn)分包策略已經(jīng)實(shí)現(xiàn)了。

到此這篇關(guān)于Vite性能優(yōu)化之分包策略的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Vite 分包內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 帶你一步步從零搭建一個(gè)Vue項(xiàng)目

    帶你一步步從零搭建一個(gè)Vue項(xiàng)目

    Vue.js是現(xiàn)在比較優(yōu)秀的Web前端框架,非常推薦大家入門學(xué)習(xí),這篇文章主要給大家介紹了關(guān)于如何一步步從零搭建一個(gè)Vue項(xiàng)目的相關(guān)資料,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • 詳解vue項(xiàng)目中調(diào)用百度地圖API使用方法

    詳解vue項(xiàng)目中調(diào)用百度地圖API使用方法

    這篇文章主要介紹了vue項(xiàng)目中調(diào)用百度地圖API使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • Vue封裝svg-icon組件使用教程

    Vue封裝svg-icon組件使用教程

    SVG(Scalable?Vector?Graphics)可縮放矢量圖形,是一種用于描述基于二維的矢量圖形的?XML?標(biāo)記語言,其基本矢量顯示對(duì)象包括矩形、圓、橢圓、多邊形、直線、任意曲線等,還能顯示文字對(duì)象和嵌入式外部圖像
    2023-02-02
  • vue使用openlayers實(shí)現(xiàn)移動(dòng)點(diǎn)動(dòng)畫

    vue使用openlayers實(shí)現(xiàn)移動(dòng)點(diǎn)動(dòng)畫

    這篇文章主要為大家詳細(xì)介紹了vue使用openlayers實(shí)現(xiàn)移動(dòng)點(diǎn)動(dòng)畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Vue優(yōu)化:常見會(huì)導(dǎo)致內(nèi)存泄漏問題及優(yōu)化詳解

    Vue優(yōu)化:常見會(huì)導(dǎo)致內(nèi)存泄漏問題及優(yōu)化詳解

    這篇文章主要介紹了Vue優(yōu)化:常見會(huì)導(dǎo)致內(nèi)存泄漏問題及優(yōu)化詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue打包后修改配置后端IP地址、端口等信息兩種方法

    vue打包后修改配置后端IP地址、端口等信息兩種方法

    這篇文章主要給大家介紹了關(guān)于vue打包后修改配置后端IP地址、端口等信息的兩種方法,文中通過代碼示例以及圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue打包具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-09-09
  • 在Vue組件化中利用axios處理ajax請(qǐng)求的使用方法

    在Vue組件化中利用axios處理ajax請(qǐng)求的使用方法

    這篇文章主要給大家介紹了在Vue組件化中利用axios處理ajax請(qǐng)求的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • Vue實(shí)現(xiàn)關(guān)聯(lián)頁面多級(jí)跳轉(zhuǎn)(頁面下鉆)功能的完整實(shí)例

    Vue實(shí)現(xiàn)關(guān)聯(lián)頁面多級(jí)跳轉(zhuǎn)(頁面下鉆)功能的完整實(shí)例

    這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)關(guān)聯(lián)頁面多級(jí)跳轉(zhuǎn)(頁面下鉆)功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • vue3如何實(shí)現(xiàn)?6位支付密碼輸入框

    vue3如何實(shí)現(xiàn)?6位支付密碼輸入框

    微信、支付寶支付密碼時(shí)的密碼輸入框大家都很熟悉,本文主要介紹了vue3如何實(shí)現(xiàn)?6位支付密碼輸入框,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • vue的token刷新處理的方法

    vue的token刷新處理的方法

    這篇文章主要介紹了vue的token刷新處理的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07

最新評(píng)論