解决axios异步请求问题(异步变为同步)

文章讲述了在Vue应用中遇到的axios异步请求问题,如何通过引入async和await来确保请求完成后再执行后续操作,特别是处理异常情况。同时,指出了async函数会返回Promise,需用.then()获取返回值,并提供了修改后的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

遇到的问题

在目前一个需求中,我需要等待axios请求完成后,判断请求是否出现异常,然后来判断是否关闭弹窗

修改后大概代码如下:

async submitForm() {
  let flag = false
  //表单验证,默认通过
  let formValidation = true
  this.$refs['vForm'].validate(valid => {
    if (!valid){
      formValidation = false
    }
    //TODO: 提交表单
  })
  if (formValidation === true){
    //这里需要使用await,否则不会等待该方法运行完成
    await insertIllegalInfo(this.formData).then(res=>{
      this.$message.success("新增成功")
      flag = true
      console.log("新增成功了")
      console.log(flag)
    })
  }
  console.log("提交马上返回了")
  console.log(flag)
  return flag
},

原来在方法中没有使用asyncawait,由于发送的axios请求是异步请求,所以在请求还没完成的时候submitForm这个方法就已经将flag返回了

这就导致了一个问题,如果我在后端在处理请求的时候出现异常,我在这里无法进行处理

经过百度搜索,发现使用async+await能够解决该问题,将异步方法改为同步方法,在方法前面加上async进行修饰,然后在axios请求前使用await进行修饰即可,这样就不会出现异步的问题

image-20230130232259421

这个问题解决后,又出现了一个新的问题,就是我在这里不是返回了一个flag吗,我在另外一个vue页面中需要获取到return返回的这个flag,但是按照正常步骤获取不到

后来经过查询资料后发现了原因,如下:

  • async 是一个修饰符,async 定义的函数会默认的返回一个Promise对象resolve的值,因此对async函数可以直接进行then操作,返回的值即为then方法的传入函数。

  • await 也是一个修饰符,await 关键字 只能放在 async 函数内部, await关键字的作用 就是获取 Promise中返回的内容, 获取的是Promise函数中resolve或者reject的值。

  • async/await 是一种编写异步代码的新方法。之前异步代码的方案是回调和 promise。

  • async/await 是建立在 promise 的基础上。(如果对Promise不熟悉,我已经着手在写Promise的文章了)

  • async/await 像 promise 一样,也是非阻塞的。

  • async/await 让异步代码看起来、表现起来更像同步代码。这正是其威力所在。

主要原因就是async 定义的函数会默认的返回一个Promise对象resolve的值,所以我们需要使用then去进行取值,如下

submitInsertIllegalInfoDialog(){
    //重要的是这里,这里调用了上面说的的submitForm方法
  this.$refs.insertIllegalInfoDialog.submitForm().then(flag=>{
      
    console.log(flag)
    if (flag === true){
      console.log("马上关闭弹窗了")
        //这个是来关闭弹窗的
      this.insertIllegalInfoDialogVisible = false
        
      console.log("重新查询")
      this.getIllegalInfoList()
      this.$refs.insertIllegalInfoDialog.resetForm();
    }
  })

},

总结

学会async和await的使用能够让我在开发vue项目的时候更加灵活,之后在遇到axios异步请求冲突的时候可以参考本篇文章进行解决

Vue中使用v-for循环渲染数据时,有时需要将循环的数据分别上传到服务器进行处理。这时可以借助axios库发送异步请求,在请求完成后再进行下一步操作。但是由于axios异步的,数据上传时可能会出现不同步的情况,导致数据上传失败或者数据顺序打乱等问题。如何解决这个问题呢? 一种解决办法是利用Promise对象的特性,将多个异步请求串联起来,使其按照顺序依次执行。具体步骤如下: 1. 定义一个方法,用于遍历数据并一次发送请求。每次请求返回一个Promise对象。 ``` uploadData(item) { return axios.post('http://www.example.com/upload', item); } ``` 2. 将循环的数据存放在一个数组中,遍历数组,将每个数据都利用uploadData方法上传到服务器,并将返回的Promise对象存放在一个数组中。 ``` let promiseArr = []; for(let item of dataArr) { promiseArr.push(this.uploadData(item)); } ``` 3. 利用Promise的静态方法all(),传入Promise数组,实现所有请求同步执行。all()返回一个新的Promise对象,该对象的then()方法中传入一个回调函数,用于处理所有请求完成后的数据。 ``` Promise.all(promiseArr).then(results => { // 处理所有请求完成后的数据 }); ``` 通过这种方法,可以将所有请求变为同步的,保证每个请求都按顺序执行,避免因异步导致上传数据不同步问题。 此外,也可以考虑使用async/await异步处理方式,async/await是ES2017引入的异步处理语法糖,能够使异步代码像同步代码一样简洁易懂。具体实现方式为,将uploadData方法用async修饰,将Promise对象转化为await表达式,实现异步代码的同步化: ``` async uploadData(item) { let res = await axios.post('http://www.example.com/upload', item); return res.data; } ``` 在遍历数据时,利用for...of循环和await表达式,逐个上传数据并等待结果: ``` for(let item of dataArr) { let res = await this.uploadData(item); // 处理每次请求的返回结果 } ``` 这样可以比较简洁地实现异步请求同步处理,但是需要注意的是,使用async/await时要确保所有请求之间的依赖关系正确,否则会导致无法同步或死循环等问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱学习的大雄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值