node.js带你解决异步困扰

1,517 阅读2分钟

「本文正在参与技术专题征文Node.js进阶之路,点击查看详情

Promise

回调地狱:嵌套层数比较多,部分元素是异步的,不是同步的,获取没有内层快,因此内层函数比外层的异步元素加载快,因此称为回调地狱

  1. promise是异步编程的一种解决方案,比传统的解决方案(回调函数和事件)更合理更强大。

  2. 使用步骤:

    • promise是一个构造函数,需要new进行创建实例
    • promise构造函数形参接收的是一个函数,函数里面一定要放入异步代码
  3. then一般用链式调用里面的函数就相当于我们平时用的回调函数一个意思,能够把原来的回调写法分离出来

  4. 异步任务成功的结果传给resolve函数,将失败的信息传给reject函数

     let p = new Promise((resolve, reject) => { resolve接收成功信息   reject接收失败  两个形参
         // ... some code
         if (/* 异步操作成功 */) {
             resolve(value);
         } else {
             reject(error);
         }
     });
     p.then(
         result => { /* 获取成功的结果 */ },
         err => { /* 获取失败的结果 */ }
     );
     ​
    

    then方法接收两个函数类型的参数,分别用于接收resolve的值和reject的值

    then方法可以只接受一个参数,表示只接收resolve的值,失败的结果可以通过链式调用catch方法捕获

async

  1. async用于修饰一个function
  2. async修饰的函数,总是返回一个Promise对象
  3. 函数的返回值,将自动包装在resolve的promise中

await

  • awaiat只能出现在async函数内

  • await让js引擎等待直到promise完成并返回结果

  • 由于await只能等待promise执行完毕,所以await会暂停函数的执行,但不会影响其他同步任务

    • await只能出现在async修饰的函数中
    • await后面跟随的是一个promise对象
    • await能停止代码执行,让后面同步代码,先执行
    • await返回的是promise对象中的then()中的回调函数中的参数

    实例:

     //删除
     async function delData(str) {
         let arr = await getData()
         let newArr = arr.filter(item => item.id != str)
         try {
             thenFs.writeFile(url, JSON.stringify(newArr))
             return "删除成功"
         } catch (e) {
             return '删除失败'
         }
     }
     ​
     /* // 测试.
     delData(9).then(res => {
         console.log(res)
     }) */
    

try和catch

  1. 在一个程序中,try可以有也可以没有,如果没有tay,程序一但异常,直接崩溃,有try的话可以保证程序继续正常运行。
  2. try的意思是,当程序正常的时候走try里面的内容。反之,程序报错的时候,走的是cath里面的内容。

格式:

     try{
     //代码区
     }catch(Exception e){
     //异常处理
     }
     代码区如果有错误,就会返回所写异常的处理。