Vue 元件太肥,切換頁面卡卡怎麼辦?讓 Suspense 登場吧!( ^ ω ^ )✧

Vue 元件太肥,切換頁面卡卡怎麼辦?讓 Suspense 登場吧!( ^ ω ^ )✧

鱈魚-avatar-img
發佈於Vue
更新於 發佈於 閱讀時間約 4 分鐘
鱈魚的魚缸搬家了!新家文章皆有重新修訂,歡迎來新家看看喔。(´▽`ʃ♡ƪ)
raw-image


醜話說在前頭,切換頁面卡卡有很多種原因,這裡舉的例子只針對元件太大的情境喔。(☆-v-)


甚麼樣的情況會讓元件太大呢?有可能是 HTML、CSS 太多,但最常見的情況就是包了太多 JS 在一起了。╮(╯▽╰)╭(import 一大堆套件等等)


除了想辦法拆分外,還有一個方法就是利用 Vue 的 Async Component。

甚麼是 Async Component?簡單來說就是在真的要用的時候才從 server 下載元件,如果熟悉 Vue Router 的朋友們對以下寫法一定不陌生:

const router = createRouter({
// ...
routes: [
{
path: '/users/:id',
component: () => import('./views/UserDetails.vue')
},
],
})

這個在 Vue Router 中稱為 Lazy Loading Routes


此概念與 Async Component 概念相同,編譯、打包時會將每個頁面拆分,只有在真的需要某頁面元件時,才從 server 下載,才不會讓進入網頁的使用者等待下載一堆還不會用到的頁面。


讓我們來一個簡單的範例:

App.vue

<script setup>
import { defineAsyncComponent } from 'vue';
import FatComp from './components/FatComp.vue';

</script>

<template>
Vue Suspense

<hr />

<FatComp />
</template>

其中 FatComp 是一個和鱈魚一樣超肥的元件,會顯示「很大很大的元件」。

鱈魚:「說好的尊重呢?(゚Д゚*)ノ」


如果我們直接 import 元件,就必須等待元件下載完成,App.vue 的畫面才會出現。


可以注意到 Vue Suspense 的文字會等到 FatComp 載入完成後才會顯示。

raw-image


如果我們使用 Suspense 改寫:

<script setup>
import { defineAsyncComponent } from 'vue';

const AsyncFatComp = defineAsyncComponent(() =>
import('./components/FatComp.vue')
);
</script>

<template>
Vue Suspense

<hr />

<Suspense>
<AsyncFatComp />

<template #fallback> Loading... </template>
</Suspense>
</template>
raw-image

可以看到 Vue Suspense 字樣先出現,肥肥的元件則會等到下載完成才出現。


恭喜頁面不卡了!✧*。٩(ˊᗜˋ*)و✧*。


Suspense 元件詳細說明可以來官方文檔看看。

以上範例程式在此,我們下次再見囉!(´▽`ʃ♡ƪ)

avatar-img
鱈魚的魚缸
17會員
14內容數
各種鱈魚滾鍵盤的雜紀
留言
avatar-img
留言分享你的想法!
鱈魚的魚缸 的其他內容
有時候使用 Pinia 會遇到資料意外變更問題,這其實不是鳳梨的錯,讓我們看看怎麼回事吧。( ´ ▽ ` )ノ
到底要用 ref 還是 reactive 是一個很常見的問題,不過現在官方文檔推薦使用 ref 就行,所以也不是甚麼大問題就是了。( •̀ ω •́ )✧ 所以 reactive 真的沒用用途了嗎?這篇文章來記錄一下 reactive 的用法。
watch 不是不能用,而是在使用 watch 之前,先想想有沒有其他方案,真的沒有才用 watch。 千萬不要為了一時方便讓元件裡滿滿的 watch,因為容易產生難以追蹤的副作用,會讓資料流更加複雜。
如果 watch 沒有放在元件最外層,可能會導致元件 onUnmounted 後watch不會自動解除,至於該怎麼辦,就讓我們娓娓道來。( ´ ▽ ` )ノ
大家好,我是鱈魚。(^∀^●)ノシ Vue 3.3 終於新增了泛型元件(Generic Component),這讓我們可以在 TypeScript 環境中得到更準確的型別提示。( •̀ ω •́ )✧ 讓我們一起來看看吧!
大家好,我是鱈魚。(。・∀・)ノ゙ 最近看到大家討論取得 API 時機,有許多人都提到「一定要」或者「習慣」,在 onMounted 這個 hook 內呼叫 API 取得資料。 其實這也沒不好,但是也沒什麼好處就是了。(。・ω・。)
有時候使用 Pinia 會遇到資料意外變更問題,這其實不是鳳梨的錯,讓我們看看怎麼回事吧。( ´ ▽ ` )ノ
到底要用 ref 還是 reactive 是一個很常見的問題,不過現在官方文檔推薦使用 ref 就行,所以也不是甚麼大問題就是了。( •̀ ω •́ )✧ 所以 reactive 真的沒用用途了嗎?這篇文章來記錄一下 reactive 的用法。
watch 不是不能用,而是在使用 watch 之前,先想想有沒有其他方案,真的沒有才用 watch。 千萬不要為了一時方便讓元件裡滿滿的 watch,因為容易產生難以追蹤的副作用,會讓資料流更加複雜。
如果 watch 沒有放在元件最外層,可能會導致元件 onUnmounted 後watch不會自動解除,至於該怎麼辦,就讓我們娓娓道來。( ´ ▽ ` )ノ
大家好,我是鱈魚。(^∀^●)ノシ Vue 3.3 終於新增了泛型元件(Generic Component),這讓我們可以在 TypeScript 環境中得到更準確的型別提示。( •̀ ω •́ )✧ 讓我們一起來看看吧!
大家好,我是鱈魚。(。・∀・)ノ゙ 最近看到大家討論取得 API 時機,有許多人都提到「一定要」或者「習慣」,在 onMounted 這個 hook 內呼叫 API 取得資料。 其實這也沒不好,但是也沒什麼好處就是了。(。・ω・。)