欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

減少 Vue 應(yīng)用白屏?xí)r間的經(jīng)驗(yàn)總結(jié)

 更新時(shí)間:2025年08月12日 09:15:26   作者:CAD老兵  
Vue 項(xiàng)目日益龐大,首屏渲染變慢、頁面打開時(shí)出現(xiàn)“白屏”的現(xiàn)象屢見不鮮,本文將系統(tǒng)講解白屏的成因,并提供多種實(shí)用優(yōu)化策略與示例代碼,幫助你在實(shí)際項(xiàng)目中顯著提升用戶體驗(yàn)

隨著前端應(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配置四種不同的圖表(示例詳解)

    在uni-app中集成ECharts可以為我們的應(yīng)用提供強(qiáng)大的圖表功能,我們?cè)敿?xì)說一下如何在uni-app中使用ECharts,并配置四種不同的圖表,感興趣的朋友跟隨小編一起看看吧
    2024-01-01
  • Vue中Vue.extend()的使用詳解及說明

    Vue中Vue.extend()的使用詳解及說明

    這篇文章主要介紹了Vue中Vue.extend()的使用詳解及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-06-06
  • Vue 3.0 前瞻Vue Function API新特性體驗(yàn)

    Vue 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-08
  • Vue3前端生成隨機(jī)id(生成?UUID)實(shí)際運(yùn)用

    Vue3前端生成隨機(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ò)位置問題

    這篇文章主要介紹了使用el-form之表單校驗(yàn)自動(dòng)定位到報(bào)錯(cuò)位置問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析

    Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析

    這篇文章主要為大家介紹了Vue實(shí)例初始化為渲染函數(shù)設(shè)置檢查源碼剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • vue3中事件處理@click的用法詳解

    vue3中事件處理@click的用法詳解

    @click指令用于監(jiān)聽元素的點(diǎn)擊事件,并在觸發(fā)時(shí)執(zhí)行相應(yīng)的處理函數(shù),在Vue3中,事件處理就可以通過@click指令來實(shí)現(xiàn),下面我們就來看看如何在Vue3中處理點(diǎn)擊事件吧
    2023-08-08
  • html+vue實(shí)現(xiàn)分頁功能的示例代碼

    html+vue實(shí)現(xiàn)分頁功能的示例代碼

    這篇文章主要為大家詳細(xì)介紹了如何使用html+vue實(shí)現(xiàn)簡(jiǎn)單的分頁功能,文中的示例代碼簡(jiǎn)潔易懂,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04
  • Monaco?Editor開發(fā)SQL代碼提示編輯器實(shí)例詳解

    Monaco?Editor開發(fā)SQL代碼提示編輯器實(shí)例詳解

    這篇文章主要為大家介紹了Monaco?Editor開發(fā)SQL編輯器實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • Vue使用mixin分發(fā)組件的可復(fù)用功能

    Vue使用mixin分發(fā)組件的可復(fù)用功能

    這篇文章主要介紹了Vue使用mixin分發(fā)組件的可復(fù)用功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09

最新評(píng)論