学习笔记 JavaScript ES8 ECMAscript 2017 异步编程Async Await

学习内容:

  • Async / Await  (异步 / 等待)

相比async/await来讲,promise在异步操作多,彼此依赖时,async/await的处理更加优雅一些。就是说,写异步操作的代码时,就像写同步操作一样顺畅,可读性很强,复杂代码可维护性强。

其实async函数是Grenerator函数的语法糖。

grenrator函数是方法上有*,里面有yield关键字,

async函数是方法名称上有async,里面有await关键字,而且await只能写在async函数的里面。

对比一个async和普通函数:

普通函数:

function foo() {
    return 'hello~'
}
console.log(foo());

---------
hello

async函数:async关键字是写在function前面的

async function foo() {
    return 'hello~' // 下面的输入相当于,return这句等价于Promise.resolve('hello~')
}
console.log(foo());

----------------------------------
Promise {<fulfilled>: 'hello~'}
[[Prototype]]: Promise
[[PromiseState]]: "fulfilled"
[[PromiseResult]]: "hello~"

下面的代码只是一个简单例子,正常await后面需要写异步操作,下面这里写个字符串没什么意义。

async function foo() {
    let result = await 'hello'
    console.log(result);
}
foo()

----------
hello

async / await的基本用法,看下面的例子,注意注释吧。。。。

function timeout() {
    return new Promise(resolve => {
        setTimeout(() => {
            console.log(1);
            resolve()
        }, 1000);
    })
} 

async function foo() {
    await timeout() // await的意思是,等待异步操作的代码timeout()执行结束之后再执行后面的代码
    console.log(2);
}

foo()

在上面的例子中,向resolve传递参数resolve(1):

function timeout() {
    return new Promise(resolve => {
        setTimeout(() => {
            resolve(1)
        }, 1000);
    })
} 

async function foo() {
    const res = await timeout()
    console.log(res); // await 异步操作执行结束后,下面两行代码才开始执行,所以先输出1,再输出2
    console.log(2);
}

foo()

------
1
2

再来看,异步操作失败的情况下,如何用async/await结合Promise来处理:

function timeout() {
    return new Promise((resolve,reject) => {
        setTimeout(() => {
            // resolve(1)
            reject('fail')
        }, 1000);
    })
} 

async function foo() {
    const res = await timeout()
    console.log(res);
    console.log(2);
}

foo().then(res => {
    console.log(res);
}).catch(err => {
    console.log(err);
})

------
fail

之前写的三个异步操作的例子,看看用async/await来实现,看看是不是特别的优雅:

先定义一个ajax请求的模块:

function ajax(url, callback) {
  var xmlhttp;
  // 1、创建XMLHttpRequest对象
  // window.XMLHttpRequest这个对象存在,说明当前浏览器是IE7+或chrome
  if (window.XMLHttpRequest) {
    xmlhttp = new XMLHttpRequest();
  } else {
    // 兼容早期浏览器
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
  }

  // 2、发送请求
  xmlhttp.open("GET", url, true);
  xmlhttp.send();

  // 3、接收服务端响应
  xmlhttp.onreadystatechange = function () {
    if (xmlhttp.readyState === 4 && xmlhttp.status === 200) {
      var obj = JSON.parse(xmlhttp.responseText);
      callback(obj)
    }
  };
}

// var url = "http://jsonplaceholder.typicode.com/users";
export default ajax

再来写三个异步操作实现:

import ajax from './ajax'
function request(url) {
    return new Promise(resolve => {
        ajax(url,res => {
            resolve(res)
        })
    })
}

async function getData() {
    const res1 = await request("http://jsonplaceholder.typicode.com/users")
    console.log(res1)
    const res2 = await request("http://jsonplaceholder.typicode.com/users")
    console.log(res2)
    const res3 = await request("http://jsonplaceholder.typicode.com/users")
    console.log(res3)
}

getData()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: JavaScriptasync/await 是用来处理异步操作的一种语法糖。它允许我们在异步函数中使用同步的写法。 我们可以使用 async 关键字来声明一个 async 函数,在 async 函数中,我们可以使用 await 关键字来等待一个异步操作的结果。 例如,我们可以使用 async/await 来等待一个 HTTP 请求的响应: ``` async function getData() { const response = await fetch('https://example.com/data.json'); const data = await response.json(); return data; } ``` 使用 async/await 可以让我们使用同步的写法来处理异步操作,这样就可以避免使用回调函数和 Promise.then() 方法了。 注意:async/await 只能在函数中使用,不能在全局作用域中使用。 ### 回答2: JavaScriptasync/await是一种处理异步操作的新特性。它是在ECMAScript 2017ES8)中引入的,用于简化Promise的使用和处理异步代码的方式。 async/await的使用方式很简单,只需要在一个函数前面加上async关键字,这样就表明该函数是一个异步函数。在异步函数中,我们可以使用await关键字来等待一个Promise对象的完成,并且可以将异步操作的结果直接赋值给一个变量。 使用async/await可以使异步代码看起来更像同步代码,这样可以提高代码的可读性和易维护性。其实现原理是通过将异步操作放在一个微任务队列中,然后在等待异步操作完成的过程中,可以继续执行后续的代码。 在使用async/await时,我们可以使用try-catch语句来捕获异步操作中产生的异常。这使得可以更方便地处理和处理异步操作中的错误。 另外,async/await还支持并行执行多个异步操作。通过使用Promise.all()方法,我们可以将多个Promise对象包装成一个新的Promise对象,然后使用await关键字等待新的Promise对象的完成。 需要注意的是,async/await只能改变异步操作的执行顺序,而不能改变异步操作本身的执行时间。所以在使用时,还是需要注意避免长时间的阻塞操作,以免影响程序的性能和响应速度。 总结来说,JavaScriptasync/await是一种用于简化处理异步操作的语法糖。它使得异步代码更容易阅读和写入,并提供了更方便的错误处理和并行执行多个异步操作的能力。这是一个非常有用的特性,在现代的JavaScript中被广泛使用。 ### 回答3: JavaScript中的async/await是一种用于处理异步操作的编程模式。它是ES8ECMAScript 2017)中引入的新特性,旨在简化异步编程,使代码更易于理解和维护。 async/await是建立在Promise的基础上的。通过在函数前面加上async关键字,可以将函数声明为一个异步函数。异步函数内部可以使用await关键字来等待一个异步操作的完成,并且返回一个Promise对象。 使用async/await可以避免使用回调函数、嵌套的Promise链和复杂的错误处理。通过async/await,代码可以按照线性的方式书写,并且保持原有的控制流结构。 在使用async/await时,可以使用try/catch块来捕获异步操作中的错误,这样就可以像处理同步操作的错误一样处理异步操作的错误。 一个典型的async/await的用法是在异步函数内部使用await关键字等待另一个异步操作的完成,然后使用得到的结果进行后续的处理。在等待异步操作时,代码会暂停执行,而不会阻塞线程。 总之,JavaScriptasync/await是一种更简洁、易读且易于维护的处理异步操作的编程模式。它提供了一种能够让开发者以线性的方式编写异步代码的方式,并且能够更好地处理异步操作中的错误。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值