減少 Vue 應(yīng)用白屏?xí)r間的經(jīng)驗(yàn)總結(jié)
隨著前端應(yīng)用不斷發(fā)展,Vue 項(xiàng)目日益龐大,首屏渲染變慢、頁面打開時(shí)出現(xiàn)“白屏”的現(xiàn)象屢見不鮮。本文將系統(tǒng)講解白屏的成因,并提供多種 實(shí)用優(yōu)化策略與示例代碼,幫助你在實(shí)際項(xiàng)目中顯著提升用戶體驗(yàn)。
什么是白屏?xí)r間?
白屏?xí)r間是指用戶從點(diǎn)擊鏈接或輸入地址到頁面開始有內(nèi)容顯示之間的這段時(shí)間。其根本原因通常包括:
- JS/CSS 資源體積大,下載與解析耗時(shí)
- 應(yīng)用初始化慢(Vue 掛載、hydrate)
- 網(wǎng)絡(luò)慢或資源未緩存
- 圖片、字體加載阻塞渲染
優(yōu)化白屏的目標(biāo)是:盡快渲染首屏關(guān)鍵內(nèi)容,并讓用戶“感知”到頁面在加載。
優(yōu)化策略總覽
優(yōu)化策略 | 適用場(chǎng)景 | 難度 | 效果 |
---|---|---|---|
預(yù)渲染 / SSR | 靜態(tài)官網(wǎng) / 內(nèi)容站 | ?? | ???????? |
路由懶加載 / 動(dòng)態(tài)導(dǎo)入 | 多頁面應(yīng)用 | ? | ?????? |
骨架屏 / 占位內(nèi)容 | 產(chǎn)品頁 / 營銷頁 | ? | ?????? |
圖片懶加載 / 字體優(yōu)化 | 圖片多 / 字體多頁面 | ? | ???? |
延遲加載重型模塊 | 圖表、監(jiān)控、動(dòng)畫 | ? | ?????? |
資源壓縮 / 緩存優(yōu)化 | 所有頁面 | ? | ???? |
內(nèi)聯(lián)關(guān)鍵 CSS / 預(yù)加載 | 內(nèi)容精簡(jiǎn)、強(qiáng)調(diào)首屏性能的頁面 | ?? | ?????? |
一、使用預(yù)渲染(Prerender)或 SSR
原理說明:
- SSR 在服務(wù)器生成 HTML,可避免客戶端加載過久才有內(nèi)容。
- 對(duì)靜態(tài)頁面,使用構(gòu)建時(shí) 預(yù)渲染(Prerender)更高效。
?? 示例:使用vite-plugin-prerender-spa實(shí)現(xiàn)預(yù)渲染
npm install vite-plugin-prerender-spa --save-dev \`\`\` \`\`\`ts // vite.config.ts import prerender from 'vite-plugin-prerender-spa' export default { plugins: [ prerender({ staticDir: 'dist', routes: ['/', '/about'] // 構(gòu)建時(shí)生成 HTML }) ] }
二、代碼拆分 + 路由懶加載
原理說明:
- 初始加載越輕,白屏越短。
- Vue 支持
import()
實(shí)現(xiàn) 組件按需加載,并與路由結(jié)合使用。
示例:
// router/index.ts import { createRouter, createWebHistory } from 'vue-router' const Home = () => import('@/views/Home.vue') const About = () => import('@/views/About.vue') export default createRouter({ history: createWebHistory(), routes: [ { path: '/', component: Home }, { path: '/about', component: About } ] })
三、使用骨架屏代替白屏
原理說明:
骨架屏是應(yīng)用加載中展示的占位元素,可用來傳達(dá)“頁面正在加載”而不是白屏狀態(tài)。
示例:簡(jiǎn)單骨架屏組件
<template> <div v-if="loading" class="skeleton"></div> <HomePage v-else /> </template> <script setup lang="ts"> import { ref, onMounted } from 'vue' import HomePage from './views/Home.vue' const loading = ref(true) onMounted(() => setTimeout(() => (loading.value = false), 1500)) </script> <style> .skeleton { height: 100vh; background: linear-gradient(90deg, #eee 25%, #ddd 50%, #eee 75%); background-size: 200% 100%; animation: shimmer 1.2s infinite; } @keyframes shimmer { 0% { background-position: -200% 0; } 100% { background-position: 200% 0; } } </style>
四、圖片懶加載與字體優(yōu)化
原理說明:
- 圖片和字體資源體積大,可能阻塞頁面渲染。
- 圖片應(yīng)懶加載;字體應(yīng)設(shè)置
font-display: swap
。
示例:
<!-- 懶加載圖片指令 --> <img v-lazy="imgUrl" /> <script setup lang="ts"> import { onMounted } from 'vue' const imgUrl = '/big-banner.jpg' </script>
// main.ts app.directive('lazy', { mounted(el, binding) { const observer = new IntersectionObserver(([entry]) => { if (entry.isIntersecting) { el.src = binding.value observer.disconnect() } }) observer.observe(el) } })
@font-face { font-family: 'MyFont'; src: url('/fonts/my-font.woff2') format('woff2'); font-display: swap; }
五、延遲加載非關(guān)鍵模塊
原理說明:
不必首屏渲染的代碼(如 ECharts、監(jiān)控 SDK、動(dòng)畫庫)應(yīng)延遲加載,避免阻塞。
示例:
onMounted(() => { requestIdleCallback(() => { import('echarts').then(echarts => { const chart = echarts.init(document.getElementById('chart')!) chart.setOption({ title: { text: '懶加載圖表' } }) }) }) })
六、使用內(nèi)聯(lián)關(guān)鍵 CSS
原理說明:
- 首屏渲染常依賴一些關(guān)鍵樣式(比如布局、導(dǎo)航欄)。
- 可通過 Vite 插件將其提取并 內(nèi)聯(lián) 到 HTML 中。
示例:
npm install vite-plugin-critical --save-dev
// vite.config.ts import critical from 'vite-plugin-critical' export default { plugins: [ critical({ criticalUrl: '', criticalBase: './dist/', criticalPages: [{ uri: '', template: 'index' }] }) ] }
七、開啟 Gzip/Brotli 壓縮
原理說明:
資源壓縮后體積顯著減少,瀏覽器解壓速度遠(yuǎn)快于傳輸速度,提升加載性能。
示例:
npm install vite-plugin-compression --save-dev
// vite.config.ts import compression from 'vite-plugin-compression' export default { plugins: [compression({ algorithm: 'gzip' })] }
八、使用 preload 加快關(guān)鍵資源加載
原理說明:
使用 <link rel="preload">
或 <link rel="modulepreload">
告訴瀏覽器:這資源是關(guān)鍵路徑,先加載它!
示例:
<!-- index.html --> <link rel="preload" href="/fonts/my-font.woff2" rel="external nofollow" as="font" type="font/woff2" crossorigin /> <link rel="modulepreload" href="/assets/main.js" rel="external nofollow" />
九、總結(jié)建議:實(shí)用組合方案
項(xiàng)目類型 | 推薦組合策略 |
---|---|
內(nèi)容靜態(tài)網(wǎng)站 | 預(yù)渲染 + 骨架屏 + 圖片懶加載 |
后臺(tái)管理系統(tǒng) | 路由懶加載 + 模塊延遲 + Gzip + 緩存優(yōu)化 |
H5 頁面 / 小程序殼 | 內(nèi)聯(lián) CSS + 字體優(yōu)化 + 骨架屏 + preload |
企業(yè)官網(wǎng) / 產(chǎn)品頁 | 預(yù)渲染 + 骨架屏 + 關(guān)鍵 CSS 提取 + preload + 動(dòng)效延遲加載 |
到此這篇關(guān)于減少 Vue 應(yīng)用白屏?xí)r間的經(jīng)驗(yàn)總結(jié)的文章就介紹到這了,更多相關(guān)減少Vue白屏?xí)r間內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
uni-app中使用ECharts配置四種不同的圖表(示例詳解)
在uni-app中集成ECharts可以為我們的應(yīng)用提供強(qiáng)大的圖表功能,我們?cè)敿?xì)說一下如何在uni-app中使用ECharts,并配置四種不同的圖表,感興趣的朋友跟隨小編一起看看吧2024-01-01Vue 3.0 前瞻Vue Function API新特性體驗(yàn)
這篇文章主要介紹了Vue 3.0 前瞻Vue Function API新特性體驗(yàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Vue3前端生成隨機(jī)id(生成?UUID)實(shí)際運(yùn)用
前端在做增刪改查時(shí)通常會(huì)使??個(gè)唯?數(shù)值做為數(shù)據(jù)的key值,下面這篇文章主要給大家介紹了關(guān)于Vue3前端生成隨機(jī)id(生成?UUID)的相關(guān)資料,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下2024-04-04使用el-form之表單校驗(yàn)自動(dòng)定位到報(bào)錯(cuò)位置問題
這篇文章主要介紹了使用el-form之表單校驗(yàn)自動(dòng)定位到報(bào)錯(cuò)位置問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-05-05Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析
這篇文章主要為大家介紹了Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08html+vue實(shí)現(xiàn)分頁功能的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何使用html+vue實(shí)現(xiàn)簡(jiǎn)單的分頁功能,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04Monaco?Editor開發(fā)SQL代碼提示編輯器實(shí)例詳解
這篇文章主要為大家介紹了Monaco?Editor開發(fā)SQL編輯器實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08