91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue3異步組件Suspense如何使用

發布時間:2023-01-28 15:28:32 來源:億速云 閱讀:118 作者:iii 欄目:開發技術

這篇文章主要介紹了Vue3異步組件Suspense如何使用的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Vue3異步組件Suspense如何使用文章都會有所收獲,下面我們一起來看看吧。

Suspense組件

官網中有提到他是屬于實驗性功能:
<Suspense> 是一項實驗性功能。它不一定會最終成為穩定功能,并且在穩定之前相關 API 也可能會發生變化。
<Suspense> 是一個內置組件,用來在組件樹中協調對異步依賴的處理。它讓我們可以在組件樹上層等待下層的多個嵌套異步依賴項解析完成,并可以在等待時渲染一個加載狀態。

意思就是此組件用來等待異步組件時渲染一些額外內容,讓應用有更好的用戶體驗

要了解 <Suspense> 所解決的問題和它是如何與異步依賴進行交互的,我們需要想象這樣一種組件層級結構:

<Suspense>
└─ <Dashboard>
   ├─ <Profile>
   │  └─ <FriendStatus>(組件有異步的 setup())
   └─ <Content>
      ├─ <ActivityFeed> (異步組件)
      └─ <Stats>(異步組件)

在這個組件樹中有多個嵌套組件,要渲染出它們,首先得解析一些異步資源。如果沒有 <Suspense>,則它們每個都需要處理自己的加載、報錯和完成狀態。在最壞的情況下,我們可能會在頁面上看到三個旋轉的加載態,在不同的時間顯示出內容。

有了 <Suspense> 組件后,我們就可以在等待整個多層級組件樹中的各個異步依賴獲取結果時,在頂層展示出加載中或加載失敗的狀態。

接下來看個簡單的例子:

首先需要引入異步組件

import {defineAsyncComponent} from 'vue'
const Child = defineAsyncComponent(()=>import('./components/Child.vue'))

簡潔一些就是用組件實現異步的加載的這么一個效果

Home父組件代碼如下:

<template>
  <div class="home">
    <h4>我是Home組件</h4>
    <Suspense>
       <template #default>
        <Child />
      </template>
      <template v-slot:fallback>
        <h4>Loading...</h4>
      </template>
    </Suspense>
  </div>
</template>
 
<script >
// import Child from './components/Child'//靜態引入
import { defineAsyncComponent  } from "vue";
const Child = defineAsyncComponent(() => import("../components/Child"));
export default {
  name: "",
  components: { Child },
};
</script>
 
<style>
.home {
  width: 300px;
  background-color: gray;
  padding: 10px;
}
</style>

自組件Child

<template>
  <div class="child">
    <h4>我是Child組件</h4>
    name: {{user.name}}
    age: {{user.age}}
  </div>
</template>

<script>
import { ref } from "vue";
export default {
  name: "Child",
  async setup() {
    const NanUser = () => {
      return new Promise((resolve, reject) => {
        setTimeout(() => {
          resolve({
            name: "NanChen",
            age: 20,
          });
        },2000);
      });
    };
    const user = await NanUser();
    return {
      user,
    };
  },
};
</script>

<style>
.child {
  background-color: skyblue;
  padding: 10px;
}
</style>

根據插槽機制,來區分組件, #default 插槽里面的內容就是你需要渲染的異步組件; #fallback 就是你指定的加載中的靜態組件。

效果如下:
Vue3異步組件Suspense如何使用

關于“Vue3異步組件Suspense如何使用”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Vue3異步組件Suspense如何使用”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

白城市| 太谷县| 通化市| 大丰市| 嵩明县| 慈溪市| 仁布县| 惠来县| 平定县| 广元市| 上林县| 秭归县| 三门峡市| 遵化市| 德江县| 响水县| 周至县| 泰州市| 申扎县| 榆树市| 新丰县| 浑源县| 延吉市| 鹿邑县| 平昌县| 株洲市| 莱芜市| 高淳县| 临桂县| 娄底市| 清原| 肥东县| 林州市| 谢通门县| 翼城县| 高邑县| 南岸区| 自治县| 西林县| 望城县| 兴安县|