Vue3异步数据加载组件suspense的使用方法

作者:天行无忌 时间:2024-04-30 10:46:09 

目录
  • 前言

  • 创建组件

  • 总结

前言

Vue3 增加了很多让人眼前一亮的特征,suspense 组件就是其中之一,对处理异步请求数据非常实用,本文通过简单的实例介绍其使用方法,如对其有兴趣,可以参阅官方文档。

通常组件在正确呈现之前需要执行某种异步请求是很常见的,通常是通过设计一种机制开发人员按照机制处理这个问题,有很多很好的方法实现这个需求。

例如,从一个 API 异步获取数据,并希望在获取响应数据解析完时显示一些信息,如 loading 效果,在Vue3中可以使用 suspense 组件来执行这样的需求。

创建组件

创建一个组件并将其命名为Peoples.vue,其组件代码如下:


<template>
   <div v-for="(people, index) in peoples.results" :key="index">
       {{ people.name }} {{ people.birth_year }}
   </div>
</template>
<script>
import { ref } from "vue";
export default {
   name: "CyPeoples",
   async setup() {
       const peoples = ref(null);
       const headers = { "Content-Type": "application/json" };
       const fetchPeoples = await fetch("https://swapi.dev/api/people", {
           headers,
       });
       peoples.value = await fetchPeoples.json();
       return { peoples };
   },
};
</script>

这里将引入 ref 以确保组件状态的反应性。因此,根据上面的代码片段,通过异步 API 调用获取电影数据。
对于VUE项目中发起 HTTP 请求,通常是使用 Axios ,这里尝试使用 fetch 。

好的,现在就来使用 suspense 在应用程序内显示数据加载中的信息。

修改 App.vue 文件,使其代码如下:


<template>
   <div>
       <h1>星球大战人物</h1>
   </div>
   <suspense>
       <template #default>
           <CyPeoples />
       </template>
       <template #fallback>
           <div>
               <h3>数据加载中……</h3>
           </div>
       </template>
   </suspense>
</template>
<script>
import CyPeoples from "./components/Peoples.vue";
import { suspense } from "vue";
export default {
   name: "App",
   components: {
       CyPeoples,
       suspense,
   },
};
</script>

从上面的代码片段中,使用组件 suspense  可以很简单就实现了 loading 的效果,带有 #default  为初始化模板组件,显示异步请求完成之后的 UI 。带有 #fallback 为异步请求中的处理 UI ,即常见的 loading 效果。

总结

suspense 组件为Vue3的一个新特性,简化异步请求UI的处理逻辑。

来源:https://juejin.cn/post/6992161407580143646

标签:vue3,异步,加载
0
投稿

猜你喜欢

  • python中的[1:]、[::-1]、X[:,m:n]和X[1,:]的使用

    2023-12-10 00:48:42
  • MySQL索引类型Normal、Unique和Full Text的讲解

    2024-01-20 09:56:19
  • 程序中常用的种代码

    2024-06-05 15:43:12
  • sqlserver2005 xml字段的读写操作

    2024-01-16 23:00:37
  • python数组循环处理方法

    2023-08-03 16:36:19
  • 基于python(urlparse)模板的使用方法总结

    2022-10-08 19:56:50
  • 使用pd.merge表连接出现多余行的问题解决

    2023-08-25 11:34:24
  • Python函数式编程的用法详解

    2021-12-21 16:16:15
  • 用python3 返回鼠标位置的实现方法(带界面)

    2021-07-17 15:11:40
  • 各种 lightbox 实现效果介绍

    2007-11-06 19:16:00
  • Python多模块引用由此引发的相对路径混乱问题

    2021-07-11 03:57:10
  • python求素数示例分享

    2021-06-16 12:01:48
  • python 实现客户端与服务端的通信

    2023-11-19 01:28:33
  • python偏函数partial用法

    2023-09-24 22:25:06
  • Python中实现参数类型检查的简单方法

    2022-07-26 18:53:07
  • python判断数字是否是超级素数幂

    2023-12-24 06:16:31
  • python使用tqdm模块处理文件阅读进度条显示

    2022-09-08 11:29:17
  • Python创建SQL数据库流程逐步讲解

    2024-01-23 14:29:17
  • Python pyinotify模块实现对文档的实时监控功能方法

    2023-04-15 08:13:52
  • DD_belatedPNG,解决IE6不支持PNG绝佳方案

    2009-04-27 16:30:00
  • asp之家 网络编程 m.aspxhome.com