Async/await,javascript异步编程

Async/await

Async/await 在学习他之前应当补充一定的 promise 知识

它是一种与 promise 相配合的特殊语法,目前被认为是异步编程的终级解决方案

值得我们每一个人学习0

Async

它的字面意思本身就是异步的简写,在代码中他被放置在函数前面,可以使得函数的返回值 value 转化为一个 promise

	async function fun(){
    return 123
	}
	const res = fun();
	console.log(res);

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pKaKmEqE-1573192102530)(C:\Users\WIN10\AppData\Roaming\Typora\typora-user-images\image-20191106145703545.png)]

如上图所示,对于非 promise 对象它会通过 Promise.resolve() 方法吧函数的 return 转化为 promise 对象,这种写法,我们便可以通过原始的 .then() 方法来获得返回值

await

await 等待,他等待着async 函数的返回值,这不仅仅适用于 Promise 对象,他适合于任何表达式结果,所以他的后面是可以接普通函数调用的直接量的,

await 如果等待到的是一个不是 Promise 对戏那个,那么 await 表达式的运算结果就是它等到的东西, 如果它等到的是一个 Promise 对象,它会阻塞后面的代码,等着 Promise 对象 resolve,然后得到 resolve 的值,作为 await 表达式的运算结果。 而他之所以被要求写在 Async 函数里面就是因为这样它会在 Promise 中异步执行

Async/await的优势

Async/await的优势就在于处理 .then() 的函数链

在处理多个 Promise 对象时,函数代码辨识度会很高,避免多个.then() 相互嵌套,

同时 await 命令后面的 Promise 对象,运行结果可能是 rejected ,所以最好把 await 命令放在 try…catch 代码块中。

//定时的函数三次异步回调
function fun() {
    const time1 = 300;
    fun1(time1)
        .then(time2 => fun2(time2))
        .then(time3 => fun3(time3))
        .then(result => {
            console.timeEnd("thefun");
        });
}

async function fun() {
    console.time("fun");
    const time1 = 300;
    const time2 = await fun1(time1);
    const time3 = await fun2(time2);
    const result = await fun3(time3);
    console.timeEnd("thefun");
}

不仅代码简洁,易读性也更好;

以上为 async/await 的基本用法,学习之前需理解 Promise 欢迎一起学习进步;

码简洁,易读性也更好;

以上为 async/await 的基本用法,学习之前需理解 Promise 欢迎一起学习进步;

  • 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 2017(ES8)中引入的,用于简化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是一种用于处理异步操作的编程模式。它是ES8(ECMAScript 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、付费专栏及课程。

余额充值