ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

关于async/await使用retrun的问题

2022-01-20 20:59:40  阅读:143  来源: 互联网

标签:返回 场景 对象 await promise Promise retrun async


场景:页面渲染数据想异步获取,封装了一个函数

async func(v) {
    let list = await get(url)
    return list[v]
}

然后调用 func 重新渲染数据,结果页面没有内容出来( 使用场景 this.text = func(v) )

后来打印(console.log(this.text))发现 返回是一个promise对象

这时候才知道 :

使用 async 定义方法,该方法会返回一个Promise对象

如果返回结果为非Promise对象,则返回一个PromiseState为fulfilled,PromiseResult为返回结果的Promise  (我的使用场景是这种)

如果返回结果为一个Promise,则返回这个Promise对象

这时候就是关于promise相关知识学习

Promise对象代表一个异步操作,有三种状态:pending(进行中)、fulfilled(已成功)和rejected(已失败)。只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态。这也是Promise这个名字的由来,它的英语意思就是“承诺”,表示其他手段无法改变。

这时候可以看到,async 函数返回的对象是一个状态为已完成的对象(我测试场景中发现这个现象,因为js本来就是一个链式对象,后面分步测试发现是promise比较快,所以状态改变了,加settimeout测试的)
 

避免再次踩坑,记录一下,当然肯定有其他解决方案实现我这个场景,下次测试了再记录!

标签:返回,场景,对象,await,promise,Promise,retrun,async
来源: https://blog.csdn.net/u012533474/article/details/122366552

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有