Vue.js 3.0 的 Suspense组件简介

开发 前端
Suspense组件是Vue3中的知名功能之一,值得庆幸的是,Suspense组件非常容易理解,它们甚至不需要任何额外的导入!

Suspense组件是Vue3中的知名功能之一。

它们允许我们的应用程序在等待异步组件时渲染一些后备内容,可以让我们创建一个平滑的用户体验。

值得庆幸的是,Suspense组件非常容易理解,它们甚至不需要任何额外的导入!

本文内容:

  • 什么是Suspense组件
  • 何时使用它
  • 如何使用
Vue.js 3.0 的 Suspense组件简介

Suspense组件到底是什么?

Suspense组件用于在等待某个异步组件解析时显示后备内容。

你可能会想我们会在什么时候使用异步组件?

老实说,超出你的想象。每当我们希望组件等待数据获取时(通常在异步API调用中),我们都可以使用Vue3 Composition API制作异步组件。

以下是异步组件有用的一些实例:

  • 在页面加载之前显示加载动画
  • 显示占位符内容
  • 处理延迟加载的图像

以前,在Vue2中,我们必须使用条件(例如 v-if 或 v-else)来检查我们的数据是否已加载并显示后备内容。

但是现在,Suspense随Vue3内置了,因此我们不必担心跟踪何时加载数据并呈现相应的内容。

[[342258]]

好吧...那我们如何实现Suspense

在这个例子中,我们有一个异步的 ArticleInfo.vue 组件。由于本文的重点是Suspense,而不是Composition API,因此,不会对这些细节进行疯狂的详细介绍。如果您对更完整的Composition API教程感兴趣,请参阅此处。

简而言之,只需知道 setup 方法可以像其他方法一样被设置为异步的。

对于我们的示例,ArticleInfo将具有异步 setup 方法,该方法将在返回之前加载用户数据。

  1. async function getArticleInfo() { 
  2.   // 一些异步API调用 
  3.   return { article } 
  4. }export default { 
  5.   async setup () {    var { article } = await getArticleInfo() 
  6.     return { 
  7.       article    }  }} 

然后,假设我们有一个 ArticlePost.vue 组件,其中包含我们的ArticleInfo组件。

如果我们要在等待组件获取数据并解析时显示“正在拼了命的加载…”之类的内容,则只需三个步骤即可实现Suspense。

  • 将异步组件包装在<template #default>标记中
  • 在我们的Async组件的旁边添加一个兄弟姐妹,标签为<template #fallback>。
  • 将两个组件都包装在<suspense>组件中

使用插槽,Suspense将渲染后备内容,直到默认内容准备就绪。然后,它将自动切换以显示我们的异步组件。

看起来会像这样。

  1. <Suspense> 
  2.   <template #default> 
  3.     <article-info/> 
  4.   </template> 
  5.   <template #fallback> 
  6.     <div>正在拼了命的加载…</div> 
  7.   </template> 
  8. </Suspense> 

你还可以捕获组件错误

Vue的另一个很酷的功能,尤其是当我们开始使用异步组件时,可以捕获错误并向用户显示一些错误消息。

即使在Vue2中,也可以使用 errorCaptured 钩子函数实现,但是在Vue3中,它已重命名为 onErrorCaptured。

无论调用什么,此钩子函数都会在捕获到任何后代组件的错误时运行。如果出现问题,我们可以将其与Suspense一起使用以渲染错误。

如果我们处理了一个错误以显示错误消息,则上面的组件将是这样。

  1. <template> 
  2.   <div v-if="errMsg"> {{ errMsg }} </div> 
  3.   <Suspense v-else> 
  4.     <template #default> 
  5.       <article-info/> 
  6.     </template> 
  7.     <template #fallback> 
  8.       <div>正在拼了命的加载…</div> 
  9.     </template> 
  10.   </Suspense> 
  11. </template> 
  12. <script> 
  13. import { onErrorCaptured } from 'vue' 
  14. setup () { 
  15.   const errMsg = ref(null) 
  16.   onErrorCaptured(e => { 
  17.     errMsg.value = '呃,出了点问题!' 
  18.     return true 
  19.   })} 
  20.   return { error } 
  21. </script> 

Vue.js 3.0 的 Suspense组件简介

结束

Suspense只是Vue使开发人员更容易解决常见问题的另一种方式。不必有条件地渲染组件,我们只需使用Suspense来为我们处理事情。

我认为,这是Vue3中最简洁的功能之一。

现在,你应该对Vue中的Suspense组件有了更多的了解,并且已经想到了一些很酷的方法来开始将它们实现到你的项目中!

 

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2017-07-11 18:00:21

vue.js数据组件

2020-09-28 17:45:03

Vue.js 3.0前端代码

2021-05-18 07:51:37

Suspense组件Vue3

2022-04-25 07:36:21

组件数据函数

2022-04-26 05:55:06

Vue.js异步组件

2019-05-29 14:23:53

Vue.js组件通信

2023-10-12 12:43:16

组件Vue

2020-06-02 14:00:53

Vue.js组件Web开发

2018-01-31 15:45:07

前端Vue.js组件

2020-04-07 09:43:17

vue.js进度组件开发

2018-04-04 10:32:13

前端JavascriptVue.js

2017-07-04 17:55:37

Vue.js插件开发

2016-11-04 19:58:39

vue.js

2024-03-13 08:37:18

Vue3Suspense异步组件

2018-07-10 15:35:33

Vue前端架构

2017-08-30 17:10:43

前端JavascriptVue.js

2023-09-27 23:08:08

Web前端Vue.jsVue3.0

2022-01-26 13:00:07

Vue.js UI组件Web

2022-01-19 22:18:56

Vue.jsVue SPA开发

2017-07-20 11:18:22

Vue.jsMVVMMVC
点赞
收藏

51CTO技术栈公众号