12,异步的发展

1,callback

ajax(xxx, ()=>{
  ajax(xxx, ()=>{
    ajax(xxx, ()=>{
      //callback函数体
    })
  })
})
解决了同步问题,排队执行。
但是回调地狱,对开发不友好。且不能try..catch,不能return

2,Promise

 ajax(xxx).then(res => {...}) .then(res => {...}) .then(res => {...})
解决了回调地狱
但是无法取消Promise。错误也需要在回调中来捕获reject

3,Generator(co函数库)

function *fetch(){
  yield ajax('xxx', () => {})
  yield ajax('xxx', () => {})
}
let it = fetch();
let result1 = it.next();
let result2 = it.next();
指针不断指向下一个Task的方式(有yield标记的地方)

4,Async/Await

async function test(){
  // 以下代码没有依赖性的话,完全可以使用 Promise.all 的方式
  // 如果有依赖性的话,其实就是解决回调地狱的例子了
  await fetch('XXX1')
  await fetch('XXX2')
  await fetch('XXX3')
}
let a = 0
let b = async () => {
  a = a + await 10
  console.log('2', a) // -> '2' 10
}
b()
a++
console.log('1', a) // -> '1' 1

//因为await内部实现了generator,会将a=0先保留下来。后面改变为1,也不影响这里。
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一、Javascript实现异步编程的过程以及原理 1、为什么要用Javascript异步编程 众所周知,Java...
    Ebony_7c03阅读 4,310评论 0 2
  • 弄懂js异步 讲异步之前,我们必须掌握一个基础知识-event-loop。 我们知道JavaScript的一大特点...
    DCbryant阅读 7,673评论 0 5
  • async 函数 含义 ES2017 标准引入了 async 函数,使得异步操作变得更加方便。 async 函数是...
    huilegezai阅读 5,013评论 0 6
  • 含义 async函数是Generator函数的语法糖,它使得异步操作变得更加方便。 写成async函数,就是下面这...
    oWSQo阅读 6,006评论 0 2
  • 前言 我们知道Javascript语言的执行环境是"单线程"。也就是指一次只能完成一件任务。如果有多个任务,就必须...
    浪里行舟阅读 14,906评论 1 27

友情链接更多精彩内容