vue中的async和await

目录

一. 错误处理和重试逻辑

二. 并发请求

三. 条件逻辑

四. 异步初始化

五. 使用 Vuex 和异步操作


在 Vue.js 中,async 和 await 的高级用法通常涉及更复杂的异步逻辑处理,包括错误处理、条件逻辑、并发请求等。以下是一些高级用法的示例:

一. 错误处理和重试逻辑

结合 try...catch 语句,你可以优雅地处理异步操作中的错误,并实现重试逻辑。

async function fetchDataWithRetry(url, maxRetries = 3) {  
  let retries = 0;  
  while (retries < maxRetries) {  
    try {  
      const response = await fetch(url);  
      if (!response.ok) throw new Error(`HTTP error! status: ${response.status}`);  
      return await response.json();  
    } catch (error) {  
      console.error(`Request failed: ${error.message}`);  
      retries++;  
      if (retries < maxRetries) {  
        console.log(`Retrying in 1 second... (${retries}/${maxRetries})`);  
        await new Promise(resolve => setTimeout(resolve, 1000));  
      } else {  
        throw error; // rethrow to be caught by the caller  
      }  
    }  
  }  
}

二. 并发请求

使用 Promise.all 可以同时发起多个异步请求,并在所有请求完成后继续执行。

async function fetchMultipleData() {  
  const urls = ['url1', 'url2', 'url3'];  
  const promises = urls.map(url => fetch(url).then(response => response.json()));  
  const results = await Promise.all(promises);  
  return results;  
}

三. 条件逻辑

在异步函数中使用 if...else 语句可以根据条件决定执行哪个异步操作。

async function conditionalFetch(condition) {  
  if (condition) {  
    const data = await fetch('url-for-true-condition').then(response => response.json());  
    return data;  
  } else {  
    const data = await fetch('url-for-false-condition').then(response => response.json());  
    return data;  
  }  
}

四. 异步初始化

在 Vue 组件的 created 或 mounted 生命周期钩子中,你可以使用 async 函数来执行异步初始化操作。

export default {  
  data() {  
    return {  
      data: null  
    };  
  },  
  async created() {  
    try {  
      this.data = await this.fetchData();  
    } catch (error) {  
      console.error('Failed to fetch data:', error);  
    }  
  },  
  methods: {  
    async fetchData() {  
      // ...fetch data logic  
    }  
  }  
};

五. 使用 Vuex 和异步操作

在 Vuex 中,你可以使用 async/await 在 action 中处理异步逻辑,而 mutations 仍然是同步的

export default new Vuex.Store({  
  state: {  
    data: null  
  },  
  mutations: {  
    setData(state, data) {  
      state.data = data;  
    }  
  },  
  actions: {  
    async fetchData({ commit }) {  
      try {  
        const response = await fetch('some-url');  
        const data = await response.json();  
        commit('setData', data);  
      } catch (error) {  
        console.error('Failed to fetch data:', error);  
      }  
    }  
  }  
});

在这个 Vuex store 的示例中,fetchData action 是异步的,它负责获取数据并通过调用 mutation 更新 state。

记住,虽然 async/await 让异步代码更易于阅读和编写,但底层仍然是基于 Promise 的。因此,理解和熟悉 Promise 是掌握这些高级用法的基础。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/366551.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MySQL-运维-主从复制

一、概述 二、原理 三、搭建 1、服务器准备 2、主库配置 &#xff08;1&#xff09;、修改配置文件/etc/my.cnf &#xff08;2&#xff09;、重启MySQL服务器 &#xff08;3&#xff09;、登录mysql&#xff0c;创建远程链接的账号&#xff0c;并授予主从复制权限 &#xff0…

微调实操一: 增量预训练(Pretraining)

1、前言 《微调入门篇:大模型微调的理论学习》我们对大模型微调理论有了基本了解,这篇结合我们现实中常见的场景,进行大模型微调实操部分的了解和学习,之前我有写过类似的文章《实践篇:大模型微调增量预训练实践(二)》利用的MedicalGPT的源码在colab进行操作, 由于MedicalGPT代…

【JS】基于React的Next.js环境配置与示例

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍基于React的Next.js环境配置与示例。 学其所用&#xff0c;用其所学。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&#xff0c;下…

小迪安全24WEB 攻防-通用漏洞SQL 注入MYSQL 跨库ACCESS 偏移

#知识点&#xff1a; 1、脚本代码与数据库前置知识 2、Access 数据库注入-简易&偏移 3、MYSQL 数据库注入-简易&权限跨库 #前置知识&#xff1a; -SQL 注入漏洞产生原理分析 -SQL 注入漏洞危害利用分析 -脚本代码与数据库操作流程 -数据库名&#xff0c…

D3842——三极管驱动,专为脱线和Dc-Dc开关电源应用设计的保护电路芯片,具有 DIP8、 SOP8两种封装形式

B3842/43/44是专为脱线和Dc-Dc开关电源应用设计的恒频电流型Pwd控制器内部包含温度补偿精密基准、供精密占空比调节用的可调振荡器、高增益混放大器、电流传感比较器和适合作功率MOST驱动用的大电流推挽输出颇以及单周期徊滞式限流欠压锁定、死区可调、单脉冲计数拴锁等保护电路…

MySQL原理(三)锁定机制(2)表锁行锁与页锁

前面提到&#xff0c;mysql锁按照操作颗粒分类&#xff0c;一般认为有表级锁、行级锁、页面锁三种。其实还有一种特殊的全局锁。 锁场景问题全局锁全库逻辑备份加了全局锁之后&#xff0c;整个数据库都是【只读状态】&#xff0c;如果数据库里有很多数据&#xff0c;备份就会花…

基于springboot校园二手书交易管理系统源码和论文

在Internet高速发展的今天&#xff0c;我们生活的各个领域都涉及到计算机的应用&#xff0c;其中包括乐校园二手书交易管理系统的网络应用&#xff0c;在外国二手书交易管理系统已经是很普遍的方式&#xff0c;不过国内的管理系统可能还处于起步阶段。乐校园二手书交易管理系统…

Python 生成图片验证码

图片验证码&#xff08;CAPTCHA&#xff09;是一种区分用户是计算机还是人的公共全自动程序。这种验证码通常以图片的形式出现&#xff0c;其中包含一些扭曲的字符或对象&#xff0c;用户需要识别这些字符或对象并输入正确的答案以通过验证。 通常情况下&#xff0c;图片验证码…

k8s中调整Pod数量限制的方法

一、介绍 Kubernetes节点每个默认允许最多创建110个pod&#xff0c;有时可能由于主机配置扩容的问题&#xff0c;从而需要修改节点pod运行数量的限制。 即&#xff1a;需要调整Node节点的最大可运行Pod数量。 一般来说&#xff0c;只需要在kubelet启动命令中增加–max-pods参数…

伯克利DeepMind联合研究,RaLMSpec让检索增强LLM速度提升2-7倍!

引言&#xff1a;知识密集型NLP任务中的挑战与RaLM的潜力 在知识密集型自然语言处理&#xff08;NLP&#xff09;任务中&#xff0c;传统的大语言模型面临着将海量知识编码进全参数化模型的巨大挑战。这不仅在训练和部署阶段需要大量的努力&#xff0c;而且在模型需要适应新数…

五款好用的在线去水印工具

我们都知道今年是AI大爆发的一年。在日常生活中&#xff0c;你是否经常在拍照时遇到照片中出现一些不必要的路人或其他元素的情况&#xff1f;通常&#xff0c;我们会使用PS软件或其他APP来处理这些问题。但是&#xff0c;对于一些不熟悉PS的朋友来说&#xff0c;这可能会是一种…

缓存击穿,商详页进不去了!!!

故事 对于小猫来讲&#xff0c;最近的一段日子是不好过的&#xff0c;纵使听着再有节拍的音乐&#xff0c;也换不起他对生活的热情。由于上一次“幂等事件”躺枪&#xff0c;他已经有几天没有休息好了。他感觉人生到了低谷。 当接手这个商城项目之后&#xff0c;他感觉他一直没…

嵌入式中C 语言中的三块技术难点

C 语言在嵌入式学习中是必备的知识&#xff0c;甚至大部分操作系统都要围绕 C 语言进行&#xff0c;而其中有三块技术难点&#xff0c;几乎是公认级别的“难啃的硬骨头”。 今天就来带你将这三块硬骨头细细拆解开来&#xff0c;一定让你看明白了。 0x01 指针 指针是公认最难理…

纷享销客渠道伙伴答谢会苏皖站:共谋高质量增长,擘画合作新篇章

2024年1月31日&#xff0c;纷享销客在南京成功举办了“凝心聚力 勇立潮头”——2024纷享销客渠道伙伴答谢会暨业务启动会|苏皖站。活动邀请了苏皖地区10余家核心渠道伙伴的代表&#xff0c;其中30余位投资人、创始人、总经理和合伙人亲临现场&#xff0c;共同探讨渠道伙伴的共赢…

数据处理Job思路总结

对工作中遇到的数据处理Job做了一些梳理&#xff0c;这里试图总结一种通用的Job开发思路。 1. Job的构成 Job 的核心元素包含&#xff1a; 任务、数据、接口、结果。 1.1 任务 数据处理任务。有些业务场景下&#xff0c;Job与任务是绑定的&#xff0c;执行一次Job就对应一个任…

光耦合器的结构与原理解析

光耦合器是一种重要的电光转换器件&#xff0c;广泛应用于电子设备、通信系统以及工业控制等领域。本文将深入分析光耦合器的结构与原理&#xff0c;旨在为读者提供清晰而全面的了解。 光耦合器作为一种关键的电子元件&#xff0c;扮演着信号隔离和传输的重要角色。它的设计结构…

【GitHub项目推荐--开箱即用的直播聊天系统,高颜值,支持二次开发】【转载】

Owncast Owncast 是一个免费开源的实时视频和网络聊天服务器&#xff0c;可与现有流行的广播软件一起使用。 github源代码&#xff1a; https://github.com/owncast/owncast 国内镜像(中文) http://www.gitpp.com/samgoat/owncast-cn 项目介绍 Owncast 是一个开源的、可…

Pycharm安装插件

经常用Pycharm写代码的话&#xff0c;时不时的就会接触到一些好用的插件&#xff0c;如何安装插件呢&#xff1f;经常使用的是两种方式&#xff0c;分别是在线安装和离线安装。 在线安装 在线安装比较简单&#xff0c;打开Pycharm&#xff0c;在左上角【文件】->【设置】-…

Portainer访问远程Docker (TLS加密)

前言&#xff1a; docker的2375端口&#xff0c;出于安全性考虑即(Docker Remote API未授权访问漏洞)&#xff0c;是不开放的&#xff0c;如果想要管理远程docker&#xff0c;可以使用TLS机制来进行访问&#xff0c;这里以Portainer访问连接为例 文章参考&#xff1a;https://b…

实习|基于SSM的实习管理系统设计与实现(源码+数据库+文档)

实习管理系统目录 目录 基于SSM的实习管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员功能介绍 &#xff08;1&#xff09;管理员登录 &#xff08;2&#xff09;实训方向管理 &#xff08;3&#xff09;公告信息管理 &#xff08;4&#xff0…