promise、async、await

一、promise

promise构造函数是同步任务,promise.then()是异步任务中的微任务。

let p = new Promise((resolve) => { console.log("成功"); })

promise.then()如果在promise里没有resolve参数时候,promise.then()是不执行的

let p = new Promise(
    ()=>{console.log("成功")}  //会在console栏打印 成功
)
p.then(()=>{console.log("111")})  //不会执行
let p = new Promise((resolve) => { console.log("成功"); })
p.then(data){
console.log(data)  //会在console栏打印 成功
}

二、async函数

async作为一个关键字放在函数前面,用来标志这是一个异步函数。

async可以理解为promise的一种简写,他的返回值是一个promise对象,不可以和回调函数一起搭配使用,可以直接运用 .then 方法,他最大的意义就是让异步代码在形式上更接近于同步代码

function fun(){
    return new Promise((resolve)=>{
        resolve(1)                       
    })
}
                                                        //这两种方法是完全相同的
async function fun (){
    return 1  //返回的值是 Promise 1 ,是个promise对象
}
fun.then((data)=>{
    console.log(data)  //用.then方法之后返回的值就是1了,此时就不再是promise对象了
})

三、await

必须在async函数中使用,且只接收resolve的值,reject的值会抛出异常用try..catch捕获

await一般后面会跟一个promise对象的表达式

let p = new Promise((resolve)=>{resolve("成功")})
async function fun(){
    let a = await p;
    console.log(a);  //输出 成功
}
fun();
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

努力学习的米

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

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

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

打赏作者

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

抵扣说明:

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

余额充值