一、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();