async await

async 函数 & await

1. async含义

async 函数,以同步的方式操作异步代码,使异步操作变得更加方便。

2. async的使用
async function show (){
    await '33'
}
let p1 = show();
2.1 await配合async使用
async function fn(){  // async 表示异步,这个函数里面有异步的任务
    let result = await xxxx;  // 表示等待await后面的结果需要等待,等出来在处理
}
4. async 的特点
  1. await 只能放到async函数中使用
  2. await后面可以是promise对象,也可以是数字,字符串,布尔值
  3. async 函数返回的是一个promise对象
  4. 只要await 语句后面的Promise的状态变成reject,那么整个async函数会中断执行
4.1 验证async函数返回一个promise对象
async function fn(){

}
console.log(fn());  //Promise

// 使用
async function fn(){
	return 'welcome';
}
fn().then(res => {
    console.log(res);    // welcome
})
4.2 如果async函数中出错
async function fn(){
    throw new Error('Error 出错了')
}
fn().then(res => {
    console.log(res);
}).catch(err => {
    console.log(err);  //  Error 出错了
})
4.3 如果await后面的语句出错,函数后面将中断执行

错误在成功之后,错误和成功都会执行

let fn = async function() {
    let data = await Promise.resolve('success');
    console.log(data)
    await Promise.reject('fail');
}
fn().then(data => console.log(data)).catch(err => console.log(err))

但是如果错误在前,成功将不会执行

async function fn(){
    await Promise.reject('出错了')
    let a = await Promise.resolve("成功了");
    console.log(a);
}
fn().then(res => {
    console.log(res);
}).catch(err => {
    console.log(err);   
})
// 打印结果
// 出错了
5. 解决async函数中的报错

如何解决async函数中抛出错误,影响后续代码执行;

这个问题比较严重,虽然是async的特点,但是我又不知道程序什么时候出错,所以我不希望出错的代码影响我后续运行

5.1使用 try { } catch (){}
1. 了解 try{} catch(err){}

try{}用来检测里面的代码,如果出现报错,会直接被catch捕获

catch(err){} 参数err就是捕获的错误,这个错误有两个属性,name,message

name: 错误的类型

message: 错误的信息

2. 错误的类型

JS常用的错误类型

ReferenceError 引用错误

TypeError 类型错误

SyntaxError 语法错误

3. 抛出错误

关键词 throw

就是将错误抛到浏览器的控制台中

4. 创建一个错误

new 关键字

创建一个新的错误

例子:

async function fn(){
    try{
        await Promise.reject('出错了')
    }catch(e){
        let a = await Promise.resolve("成功了");
        console.log(a);
    }
}
5.2 添加catch 捕获错误

本来await后面的就是promise,那么我们就可以直接使用catch处理

async function fn(){
    await Promise.reject('出错了').catch(err=>{
        console.log(err);
    })
    let a = await Promise.resolve("成功了");
    console.log(a);
}

其实跟网络打交道的都不保险,你不可能给每一个await后面的promise对象都加catch

5.3 统一捕获错误

个人建议,只要有await的地方都try catch掉 然后统一处理结果

try {
    let f1 = await Promise.resolve('成功了');
    let f2 = await Promise.resolve('成功了');
    let f3 = await Promise.reject('出错了');
}catch(e){}
5.4 也可以是用Promise.all()方法

如果你多次请求的数据之间没有关联,就可以使用Promise.all()

// async 
async function fn(){
    let [f1,f2,f3] = await Promise.all([
        Promise.resolve('成功了1'),
       	Promise.resolve('成功了2'),
        Promise.resolve('成功了3')
    ])


    console.log(f1);
    console.log(f2);
    console.log(f3);
}
fn();

同时配合解构处理

例子:

async function show() {
    let p1 = await new Promise((res, rej) => {
        $.ajax({
            url: 'https://jsonplaceholder.typicode.com/todos/1',
            success: function(data) {
                res(data)
            },
            error: function(err) {
                rej()
            }
        })
    });
    console.log(p1)
    let p2 = await new Promise((res, rej) => {
        $.ajax({
            url: 'https://jsonplaceholder.typicode.com/todos/2',
            success: function(data) {
                res(data)
            },
            error: function(err) {
                rej()
            }
        })
    });
    console.log(p2)

}

let pp = show()
### 回答1: async/await 是 JavaScript 中的异步编程机制,旨在简化异步代码的编写。使用 async/await 可以让异步代码的执行流程更加类似于同步代码,从而提高代码的可读性和可维护性。 当一个函数前面加上关键字 `async`,该函数就成为了一个异步函数。异步函数中可以使用 `await` 关键字等待一个异步操作(例如一个 Promise 的 resolve)完成,在该异步操作完成之前,函数的执行将会暂停。 例如: ``` async function fetchData() { const response = await fetch('https://api.example.com/data'); const data = await response.json(); return data; } ``` 在上面的代码中,我们使用了 `await` 关键字等待 `fetch` 函数的返回值,这意味着当我们调用 `fetchData` 函数时,代码将会暂停,直到请求完成为止。 ### 回答2: async/await 是 ECMAScript 2017 引入的一种语法糖,用于简化异步编程的写法。通过使用 async 和 await 关键字,可以将异步代码以同步的方式编写,增强代码的可读性和维护性。 async 关键字用于声明一个函数是异步的,当函数被调用时,它会返回一个 Promise 对象。在函数体内,可以使用 await 关键字来暂停函数的执行,等待 Promise 对象的状态变为 resolved,然后获取到 Promise 的结果。 使用 async/await 可以避免传统的回调地狱,代码结构更清晰、更易理解。通过 await 关键字,可以实现按照自然的顺序编写异步代码,而不必使用嵌套的回调函数。 另外,async/await 还具有错误处理的能力。可以使用 try-catch 块来捕获和处理异步操作中的异常。在 async 函数内部,如果出现异常,可以使用 throw 关键字抛出异常,然后在调用该函数的地方使用 try-catch 来捕获并处理异常。 需要注意的是,await 关键字只能在 async 函数中使用。如果在非 async 函数中使用 await,会导致语法错误。 总之,async/await 是一种语法糖,用于简化异步编程的写法。它通过 async 和 await 关键字,让异步代码以同步的方式编写,提高代码的可读性和可维护性。同时,它还具备错误处理的能力,让程序员能够更方便地处理异步操作中的异常。 ### 回答3: async await是JavaScript中一种用来处理异步操作的语法。在过去,处理异步操作通常使用回调函数或者Promise,但是这两种方式都会导致代码的嵌套层级过深,降低代码的可读性和维护性。而async await则可以使异步代码更加简洁和易读。 使用async await,我们可以在异步函数前面加上async关键字,使其成为一个异步函数。在异步函数中,我们可以使用await关键字等待一个异步操作的结果,而不需要使用回调函数或者处理Promise的then和catch。 具体来说,async await的工作原理是将异步操作转换为一个Promise对象,然后使用await关键字等待该Promise的解决结果。当await关键字后面的Promise解决之后,将其结果返回给异步函数,并继续执行后面的代码。 使用async await可以使异步代码具有同步代码的写法风格,提高代码的可读性和可维护性。它能够避免回调地狱的问题,使异步操作更加直观和易于理解。此外,由于async await基于Promise实现,所以它也具有Promise的一些优点,比如可以很方便地进行错误处理和链式调用。 总结来说,async await是JavaScript中用于处理异步操作的一种语法糖,通过使用async关键字定义一个异步函数,再用await关键字等待异步操作的结果,使异步代码具有同步代码的风格,提高代码的可读性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值