自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

VUE項(xiàng)目性能優(yōu)化實(shí)踐——通過懶加載提升頁面響應(yīng)速度

開發(fā) 前端
懶加載也叫做延時(shí)加載,在網(wǎng)頁響應(yīng)時(shí)不立刻請(qǐng)求資源,待頁面加載完畢或者按需響應(yīng)時(shí)再加載資源,以達(dá)到提高頁面響應(yīng)速度以及節(jié)省服務(wù)器資源的謎底。

 最近我司因業(yè)務(wù)需求,需要在一個(gè)內(nèi)部數(shù)據(jù)分析平臺(tái)集成在線Excel功能,既然我們自己就是做開發(fā)工具的,所以目光自然就落在了我司自研的前端表格產(chǎn)品上。

項(xiàng)目的目的是要通過數(shù)據(jù)透視表和Excel公式來分析公司的各項(xiàng)運(yùn)營(yíng)數(shù)據(jù)。不過在集成后,在開發(fā)環(huán)境頁面運(yùn)行流暢,大量數(shù)據(jù)加載處理也很快。但是發(fā)布生產(chǎn)后,在用戶每次打開頁面時(shí),加載時(shí)間上相較開發(fā)階段均有所降低,經(jīng)過排查速度變慢是由于發(fā)布包的vendor.js變大所導(dǎo)致的,這個(gè)文件加載每次都需300毫秒左右,由于小的Vue項(xiàng)目并沒有做模塊劃分,所以所有的代碼都直接打包到了vendor中,在集成了新功能后,發(fā)布包也隨之變大了。

既然找到了原因,我們就開始著手優(yōu)化,在前端對(duì)于需加載較大資源時(shí),我們一般都采用懶加載的方式來優(yōu)化效率。

什么是懶加載?

懶加載也叫做延時(shí)加載,在網(wǎng)頁響應(yīng)時(shí)不立刻請(qǐng)求資源,待頁面加載完畢或者按需響應(yīng)時(shí)再加載資源,以達(dá)到提高頁面響應(yīng)速度以及節(jié)省服務(wù)器資源的謎底。網(wǎng)頁中常用的懶加載是圖片的懶加載,對(duì)于類似淘寶一樣的多圖頁面,如果等待所有圖片都下載完成再響應(yīng)用不必然造成頁面加載的卡頓。對(duì)于JS資源的加載也是同樣的道理,大JS的加載會(huì)造成JS阻塞,頁面出現(xiàn)停止響應(yīng)的假死狀態(tài)。因此可以通過按需加載的方式,提高頁面首屏的加載速度。

總結(jié)了具體優(yōu)化步驟,下面我們就開始著手優(yōu)化吧!

開始優(yōu)化

首先是項(xiàng)目環(huán)境:Vue 2.6

開發(fā)環(huán)境:Vue-cli 4.5 + TypeScript 3.9

劃分業(yè)務(wù)模塊

通過路由異步加載模塊,加速首屏以及其他頁面加載速度,在Vue Router中將webExcel模塊配置為懶加載模式,配置后webExcel組件會(huì)按照指定的webpackChunkName打包為單獨(dú)的文件,并在訪問webExcel路由的時(shí)候才會(huì)加載。這樣訪問home以及about頁面時(shí)并不會(huì)加載webExcel資源。

懶加載路由配置

打包發(fā)布訪問頁面,首屏秒開,直接訪問about依舊秒開。可是查看網(wǎng)絡(luò)請(qǐng)求時(shí)候發(fā)現(xiàn)訪問首頁時(shí)請(qǐng)求了about和web Excel的資源。經(jīng)過排查發(fā)現(xiàn)vue-cli在頁面中使用了preload和prefetch預(yù)加載機(jī)制,在不影響當(dāng)前頁面加載的情況下預(yù)加載后續(xù)頁面需要的資源提升用戶體驗(yàn),這里為了演示清晰注釋掉prefetch的資源。

(臨時(shí)禁用prefetch預(yù)加載)

開啟路由懶加載后首頁并未加載about和webExcel。

(首頁Home網(wǎng)絡(luò)請(qǐng)求)

清理網(wǎng)絡(luò)請(qǐng)求記錄,點(diǎn)擊Web Excel,訪問webExcel頁面,此時(shí)會(huì)請(qǐng)求webExcel資源并展示組件。

(webExcel頁面網(wǎng)絡(luò)請(qǐng)求)

在線Excel組件懶加載,進(jìn)一步優(yōu)化使用插件頁面打開速度

優(yōu)化了路由加載,為了提升用戶體驗(yàn),進(jìn)一步優(yōu)化webExcel頁面,開啟組件懶加載,當(dāng)需要Designer組件的時(shí)候再加載。

開啟異步組件的方式類似于路由,直接配置import組件即可,替換原有的靜態(tài)import。

(組件懶加載)

這里我們一步到位使用AsyncComponent配置,這樣在加載組件(loading)時(shí)候可以給用戶一個(gè)提示。

(頁面模板)

(異步組件懶加載)

頁面上通過displayDesigner屬性控制Designer組件是否顯示,setTimeout 3秒后開始加載Designer組件并展示。LoadingComponent在加載時(shí)展示loading狀態(tài)。

可以從網(wǎng)絡(luò)請(qǐng)求中看到,webExcel加載完3秒后開始請(qǐng)求designer資源,請(qǐng)求時(shí)顯示LoadingComponent,請(qǐng)求完畢展示Desinger 組件。

開啟gzip壓縮,加速資源請(qǐng)求速度

為了進(jìn)一步加速資源請(qǐng)求,可以開啟服務(wù)器gizp壓縮,目前大部分瀏覽器都支持gzip,可以開啟服務(wù)器的gzip功能,服務(wù)器在傳輸資源之前先進(jìn)行壓縮。

網(wǎng)絡(luò)請(qǐng)求Request中會(huì)出現(xiàn)如下內(nèi)容,就表示支持gzip

Accept-Encoding: gzip, deflate, br

Vue-cli可以在打包時(shí)就將資源提前進(jìn)行g(shù)zip打包,這樣服務(wù)器直接返回打包后的資源不需要再次打包了。通過使用compression-webpack-plugin插件可以在打包時(shí)直接生成gz壓縮文件。關(guān)于gzip的配置可以根據(jù)具體部署情況設(shè)置。

總結(jié)

經(jīng)過以上優(yōu)化,首屏加載資源僅需Vue基礎(chǔ)組件和Home頁面組件,首屏加載速度回復(fù)到原始200毫秒。其他未使用Designer組件的頁面也無需加載資源,同時(shí)Designer組件加載一次,后續(xù)其他頁面再使用組件也無需再次加載

以上就是關(guān)于Vue路由和組件懶加載的一些配置,不過懶加載不是萬能的,還是要從實(shí)際需求出發(fā)決定是否使用。

 

責(zé)任編輯:張燕妮 來源: 葡萄城官網(wǎng)
相關(guān)推薦

2024-07-23 08:08:18

2009-06-16 15:04:14

JSP頁面響應(yīng)速度

2014-03-31 16:15:47

移動(dòng)應(yīng)用優(yōu)化

2025-02-19 13:00:00

移動(dòng)端觸摸事件響應(yīng)速度JavaScrip

2011-08-29 17:16:29

Ubuntu

2020-07-17 19:55:50

Vue前端性能優(yōu)化

2024-12-26 11:01:22

2025-03-10 00:00:50

2016-02-15 10:52:46

視頻會(huì)議華為

2022-02-22 16:21:04

Windows 11微軟

2021-03-19 06:31:06

vue-lazyloa圖片懶加載項(xiàng)目

2024-02-01 09:51:17

數(shù)據(jù)庫緩存

2021-02-21 11:40:25

技術(shù)優(yōu)化實(shí)踐

2022-10-14 08:47:42

埋點(diǎn)統(tǒng)計(jì)優(yōu)化

2019-12-09 09:34:47

緩存響應(yīng)數(shù)據(jù)

2022-06-13 09:45:51

Hook技術(shù)移動(dòng)應(yīng)用響應(yīng)速度

2009-06-24 15:16:19

AJAX客戶端

2016-09-30 13:11:31

前端后端網(wǎng)頁速度

2019-09-24 09:25:05

Vue項(xiàng)目加載

2015-10-29 09:40:54

優(yōu)化頁面加載速度
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)