async-await 的简单理解,generator函数

同步与异步

常见的异步操作:定时器、ajax、事件处理函数、node.js

回调地狱

ajax请求中回调函数套回调函数,多层嵌套形成回调地狱

解决回调地狱问题

ajax+promise:promise对象的形参是一个函数,该函数又有两个函数形参,resolve和reject,分别表示成功和失败时调用。

let a=new Promise(function(resolve,reject){
    ajax({
    url:"/xxx",
    success:function(res){
        resolve(res)
    }
    })
})
a.then(function(res){
    let b=new Promise(function(resolve,reject){
    ajax({
    url:"/xxx",
    success:function(res){
        resolve(res)
    }
    })
})

用promise将ajax封装

function axios(){
let a=new Promise(function(resolve,reject){
    ajax({
    url:"/xxx",
    success:function(res){
        resolve(res)
    }
    })
})
return a;
}
axios().then(function (res){
    console.log(res);
})

async await 的作用就是省略then写法

async ()=>{
    let res=await axios();
    console.log(res);
}

async就是Generator函数的语法糖,简化写法。

Generator函数

ES6提出的一种异步编程解决方案

//function与函数名之间需要有一个 *
function* fun(){
    //yield表示暂停 将函数分了段
    yield '111'
    yield '222'
    return 'result'
}
//调用fun函数
var res1=fun();//这里res1的值并不是fun函数的返回值,函数在yield时暂停了,拿到的应该是一个暂停标记,且指向111
res1.next();//拿到暂停的值 111
res1.next();//222
res1.next();//result

await的作用就是像yield那样,在发起多个aiax时,一个一个拿结果,但是其写法相对简单,注意:await在使用时,一定要对函数用async修饰。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值