中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Vue的異步組件怎么使用

發布時間:2023-04-21 14:36:01 來源:億速云 閱讀:102 作者:iii 欄目:開發技術

這篇文章主要講解了“Vue的異步組件怎么使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Vue的異步組件怎么使用”吧!

基本用法

在大型項目中,我們可能需要拆分應用為更小的塊,并僅在需要時再從服務器加載相關組件。Vue 提供了defineAsyncComponent方法來實現此功能:

import { defineAsyncComponent } from 'vue'
 
const AsyncComp = defineAsyncComponent(() => {
  return new Promise((resolve, reject) => {
    // ...從服務器獲取組件
    resolve(/* 獲取到的組件 */)
  })
})
// ... 像使用其他一般組件一樣使用 `AsyncComp`

如你所見,defineAsyncComponent方法接收一個返回 Promise 的加載函數。這個 Promise 的resolve回調方法應該在從服務器獲得組件定義時調用。你也可以調用reject(reason)表明加載失敗。

ES 模塊動態導入也會返回一個 Promise,所以多數情況下我們會將它和defineAsyncComponent搭配使用。類似 Vite 和 Webpack 這樣的構建工具也支持此語法 (并且會將它們作為打包時的代碼分割點),因此我們也可以用它來導入 Vue 單文件組件:

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

最后得到的AsyncComp是一個外層包裝過的組件,僅在頁面需要它渲染時才會調用加載內部實際組件的函數。它會將接收到的 props 和插槽傳給內部組件,所以你可以使用這個異步的包裝組件無縫地替換原始組件,同時實現延遲加載。

與普通組件一樣,異步組件可以使用app.component()全局注冊:

app.component('MyComponent', defineAsyncComponent(() =>
  import('./components/MyComponent.vue')
))

你也可以在局部注冊組件時使用defineAsyncComponent

<script>
import { defineAsyncComponent } from 'vue'
 
export default {
  components: {
    AdminPage: defineAsyncComponent(() =>
      import('./components/AdminPageComponent.vue')
    )
  }
}
</script>
 
<template>
  <AdminPage />
</template>

加載與錯誤狀態

異步操作不可避免地會涉及到加載和錯誤狀態,因此defineAsyncComponent()也支持在高級選項中處理這些狀態:

const AsyncComp = defineAsyncComponent({
  // 加載函數
  loader: () => import('./Foo.vue'),
 
  // 加載異步組件時使用的組件
  loadingComponent: LoadingComponent,
  // 展示加載組件前的延遲時間,默認為 200ms
  delay: 200,
 
  // 加載失敗后展示的組件
  errorComponent: ErrorComponent,
  // 如果提供了一個 timeout 時間限制,并超時了
  // 也會顯示這里配置的報錯組件,默認值是:Infinity
  timeout: 3000
})

如果提供了一個加載組件,它將在內部組件加載時先行顯示。在加載組件顯示之前有一個默認的 200ms 延遲&mdash;&mdash;這是因為在網絡狀況較好時,加載完成得很快,加載組件和最終組件之間的替換太快可能產生閃爍,反而影響用戶感受。

如果提供了一個報錯組件,則它會在加載器函數返回的 Promise 拋錯時被渲染。你還可以指定一個超時時間,在請求耗時超過指定時間時也會渲染報錯組件。

搭配 Suspense 使用

異步組件可以搭配內置的<Suspense>組件一起使用。

感謝各位的閱讀,以上就是“Vue的異步組件怎么使用”的內容了,經過本文的學習后,相信大家對Vue的異步組件怎么使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

vue
AI

思茅市| 太仆寺旗| 福海县| 沈阳市| 德兴市| 灌南县| 麦盖提县| 视频| 高青县| 八宿县| 井陉县| 资兴市| 湘西| 武平县| 聂拉木县| 通化市| 竹山县| 扎囊县| 娄烦县| 开原市| 无锡市| 滨海县| 乐清市| 苏尼特左旗| 吴忠市| 横山县| 麻江县| 汉寿县| 光泽县| 黄梅县| 望谟县| 高陵县| 噶尔县| 桑植县| 怀来县| 儋州市| 怀远县| 邯郸市| 蓬莱市| 林口县| 大渡口区|