如何同步拿到异步函数返回值

当我们遇到异步函数的时候,会先执行后续代码,等异步执行完毕才能拿到异步返回的值,而有的时候我们需要同步拿到异步返回的值之后再去执行后续操作

下面就是一个异步代码的执行,返回顺序从后往前 

function resolveAfter2Seconds(){
  setTimeout(() => {
      console.log('成功');
  }, 100);
  console.log("你好")
}

resolveAfter2Seconds()    // 先打印"你好",再打印"成功"

需要同步拿到异步函数的返回值,首先利用promise先去定义异步函数,返回成功/错误值,然后调用promise函数接收值,以下是两种写法

第一种, 直接调用函数,然后.then拿值,执行后续操作

function resolveAfter2Seconds() {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('成功');
    }, 2000);
  });
}


resolveAfter2Seconds().then((r)=>{
	console.log(r)
	console.log("你好")    //先输出‘成功’,在输出‘你好’
  
  //执行拿到异步返回的值之后的操作...
})

第二种,利用async重新定义一个函数,在里面利用await接收promise函数的返回值,然后进行后续操作 

function resolveAfter2Seconds() {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('成功');
    }, 2000);
  });
}

async function asyncCall() {
  const result = await resolveAfter2Seconds();
  console.log(result);
  console.log('你好');  //先输出‘成功’,在输出‘你好’

  //执行拿到异步返回的值之后的操作...
}

asyncCall();

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 可以使用 async/await 关键字来实现在普通函数中直接拿到异步函数返回值。具体做法是在普通函数中使用 await 关键字调用异步函数,这样就可以直接拿到异步函数返回值。需要注意的是,普通函数必须是 async 函数才能使用 await 关键字。 ### 回答2: 在普通函数中直接获取异步函数返回值是一种常见的需求,可以通过以下几种方法实现: 1. 使用回调函数:在调用异步函数时,传入一个回调函数作为参数,在异步函数执行完毕后,将返回值作为参数传递给回调函数。这样在普通函数中就可以直接通过回调函数获取异步函数返回值。 2. 使用Promise对象:将异步函数封装成一个Promise对象。在异步函数执行完毕后,通过调用Promise对象的resolve方法返回值传递给普通函数。普通函数可以通过调用Promise对象的then方法获取异步函数返回值。 3. 使用async/await关键字:将异步函数声明为async函数,然后在普通函数中通过await关键字调用异步函数。await关键字会暂停当前函数的执行,直到异步函数执行完毕并返回结果。普通函数可以直接获取异步函数返回值。 需要注意的是,无论使用哪种方法异步函数的执行时间可能会较长,因此在普通函数获取异步函数返回值时,应该确保异步函数执行完毕并返回结果,否则可能会得到undefined或者其他错误的值。 ### 回答3: 在普通函数中直接获取异步函数返回值是一个常见的需求。为了实现这个目标,我们可以使用一些技巧和方法。 首先,我们需要了解异步函数的特性。异步函数是不能直接返回结果的,因为它们会返回一个Promise对象。Promise对象可以通过调用then()方法获取异步操作的结果。 那么在普通函数中,我们可以利用Promise对象来获取异步函数返回值。具体步骤如下: 1. 使用Promise对象包裹异步函数,然后将Promise对象返回。这可以让我们在外部调用函数时捕获Promise对象。 2. 在调用异步函数的普通函数中,使用await关键字来等待Promise对象完成。这会暂停代码执行,直到Promise对象解决为止。 3. 使用try-catch语句块来捕获Promise对象抛出的错误。这可以确保我们在出现错误时能够正确处理异常情况。 下面是一个示例代码,演示了如何在普通函数中直接获取异步函数返回值: ```javascript function asyncFunc() { return new Promise((resolve, reject) => { setTimeout(() => { resolve("异步函数返回值"); }, 1000); }); } async function normalFunc() { try { const result = await asyncFunc(); console.log(result); } catch (error) { console.error(error); } } normalFunc(); ``` 在上面的代码中,我们定义了一个asyncFunc()异步函数,该函数返回一个在1秒后解决的Promise对象。然后,在normalFunc()普通函数中,我们使用await关键字等待asyncFunc()函数的结果。最后,我们将结果打印到控制台上。 这样通过使用Promise对象和await关键字,我们可以在普通函数中直接获取异步函数返回值

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值