首页 >

详细了解Nodejs中的Promise对象

web前端|js教程详细了解Nodejs中的Promise对象
Nodejs,Promise对象
web前端-js教程
本篇文章带大家了解一下Nodejs中的Promise对象
神界online全套源码,vscode上下左右快捷键,ubuntu安装oneok,tomcat安装两个,爬虫馆标语,php显示pdf文件,天津seo排名转化率好吗lzw
易酷影视网站源码,ubuntu 显卡扩展坞,沙爬虫可以养殖,php longip,兴化seo顾问lzw
《nodejs 教学》
3389批量管理源码,vscode的f10不能用,ubuntu重启解决,tomcat如何设为自启,桃源爬虫防治,php订单查询系统源码,百度广告投放平台seolzw
Promise对象

1. promise用来做什么?

我们的需求是一次的去执行异步代码

我们的做法是在异步请求成功后的回调函数里,执行下一个异步请求

但是这样就出现了回调地狱(回调函数中嵌套了回调函数,代码的阅读性 低,维护不变,让人看着害怕)

promise就是用来解决回调地狱的

// 需求:一次的读取a,b,c这三个文件const fs = require("fs");// 读a文件fs.readFile(`${__dirname}/etc/a.txt`, "utf-8", (err, data) => {  if (err) {    console.log(err);  } else {    console.log(data);    // 读b文件    fs.readFile(`${__dirname}/etc/b.txt`, "utf-8", (err, data) => {      if (err) {        console.log(err);      } else {        console.log(data);        // 读c文件        fs.readFile(`${__dirname}/etc/c.txt`, "utf-8", (err, data) => {          if (err) {            console.log(err);          } else {            console.log(data);          }        });      }    });  }});

2. promise工作流程

es6的语法,es6.ruanyifeng.com

Promise对象是一个构造函数 ,用来生成promise实例

Promise构造函数接受一个函数作为参数

这个作为参数的函数,又有两个参数,这两个参数分别是resolve和reject

这两个参数它们也是函数,只不过这两个函数由 javascript 引擎提供,不用自己部署

异步操作成功后调用resolve()方法,他内部调用了then()里面的第一个参数函数

异步操作成功后调用reject()方法,他内部调用了then()里面的第二个参数函数.

const fs = require("fs");// 调用Promise构造函数,创建一个promise的实例let p = new Promise((resolve, reject) => {  // 写异步操作(读文件)  fs.readFile(`${__dirname}/etc/a.txt`, "utf-8", (err, data) => {    if (!err) {      // 操作成功(读文件成功)      resolve(data); // 调用resolve方法      // 调用then()里面的第一个参数函数    } else {      reject(err); // 调用reject方法      // 调用then()里面的第二个参数函数    }  });});p.then(  (data) => {    console.log(data);  },  (err) => {    console.log(err);  });

3. promise原理

Promise对象代表一个异步操作.

有三种状态: pending (进行中)、fulfilled (已成功)和rejected (已失败)

Promise对象的状态改变,只有两种可能:从pending变 为fulfilled和从pending变为rejected。

只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态

如果异步操作成功了(读文件成功了),从pending (进行中)变为 fulfilled (已成功) ;

如果异步操作失败了(读文件失败了),从pending (进行中)变为 rejected (已失败) ;

状态如果已经确定了, 就不会再去改变这个状态了

4. promise特点及其封装

Promise新建后就会立即执行

所以不要在promise里面写其他的代码,只写这个异步操作的代码就可以了

const fs = require("fs");function getPromise(filename) {  // 调用Promise构造函数,创建一个promise的实例  return new Promise((resolve, reject) => {    // 写异步操作(读文件)    fs.readFile(`${__dirname}/etc/${filename}.txt`, "utf-8", (err, data) => {      if (!err) {        // 操作成功(读文件成功)        resolve(data); // 调用resolve方法        // 调用then()里面的第一个参数函数      } else {        reject(err); // 调用reject方法        // 调用then()里面的第二个参数函数      }    });  });}// console.log(getPromise("a"));getPromise("a").then(  (data) => {    console.log(data);  },  (err) => {    console.log(err);  });

5. promise正确写法

**我们用promise解决的问题:让异步操作有顺序,并且不能有回调地狱 **

让异步操作有顺序本质是:

异步操作实际上是没有顺序的

在异步操作成功后的回调函数里返回另外的promise,调用他的then方法

const fs = require("fs");function getPromise(filename) {  // 调用Promise构造函数,创建一个promise的实例  return new Promise((resolve, reject) => {    // 写异步操作(读文件)    fs.readFile(`${__dirname}/etc/${filename}.txt`, "utf-8", (err, data) => {      if (!err) {        // 操作成功(读文件成功)        resolve(data); // 调用resolve方法        // 调用then()里面的第一个参数函数      } else {        reject(err); // 调用reject方法        // 调用then()里面的第二个参数函数      }    });  });}// console.log(getPromise("a"));getPromise("a")  .then((data) => {    console.log(data);    //调用函数得到一个读b文件的promise对象并返回    return getPromise("b");  })  .then((data) => {    console.log(data);    //调用函数得到一个读c文件的promise对象并返回    return getPromise("c");  })  .then((data) => {    console.log(data);  });

6. promise的其他方法

catch()

const fs = require("fs");function getPromise(filename) {  // 调用Promise构造函数,创建一个promise的实例  return new Promise((resolve, reject) => {    // 写异步操作(读文件)    fs.readFile(`${__dirname}/etc/${filename}.txt`, "utf-8", (err, data) => {      if (!err) {        // 操作成功(读文件成功)        resolve(data); // 调用resolve方法        // 调用then()里面的第一个参数函数      } else {        reject(err); // 调用reject方法        // 调用then()里面的第二个参数函数      }    });  });}// console.log(getPromise("a"));getPromise("a")  .then((data) => {    console.log(data);    //调用函数得到一个读b文件的promise对象并返回    return getPromise("b");  })  .then((data) => {    console.log(data);    //调用函数得到一个读c文件的promise对象并返回    return getPromise("c");  })  .then((data) => {    console.log(data);  })  .catch((err) => {    console.log(err);  });

all()

const fs = require("fs");function getPromise(filename) {  // 调用Promise构造函数,创建一个promise的实例  return new Promise((resolve, reject) => {    // 写异步操作(读文件)    fs.readFile(`${__dirname}/etc/${filename}.txt`, "utf-8", (err, data) => {      if (!err) {        // 操作成功(读文件成功)        resolve(data); // 调用resolve方法        // 调用then()里面的第一个参数函数      } else {        reject(err); // 调用reject方法        // 调用then()里面的第二个参数函数      }    });  });}let p1 = getPromise("a");let p2 = getPromise("b");let p3 = getPromise("c");// Promise.all()方法用于将多个 Promise 实例,包装成一个新的 Promise 实例let pAll = Promise.all([p1, p2, p3]);// 一个都不能少,每一个promise都要读取成功才会成功,相当于是并且pAll.then((data) => {  console.log(data);});

race

const fs = require("fs");function getPromise(filename) {  // 调用Promise构造函数,创建一个promise的实例  return new Promise((resolve, reject) => {    // 写异步操作(读文件)    fs.readFile(`${__dirname}/etc/${filename}.txt`, "utf-8", (err, data) => {      if (!err) {        // 操作成功(读文件成功)        resolve(data); // 调用resolve方法        // 调用then()里面的第一个参数函数      } else {        reject(err); // 调用reject方法        // 调用then()里面的第二个参数函数      }    });  });}let p1 = getPromise("a");let p2 = getPromise("b");let p3 = getPromise("c");// Promise.race()方法同样是将多个 Promise 实例,包装成一个新的 Promise 实例let pRace = Promise.race([p1, p2, p3]);// 只要有一个promise执行成功,那这个pRace就成功,相当于是或者pRace.then((data) => {  console.log(data);});

编程视频!!


详细了解Nodejs中的Promise对象
  • 如何使用JavaScript中的promise对象
  • 如何使用JavaScript中的promise对象 | 如何使用JavaScript中的promise对象 ...

    详细了解Nodejs中的Promise对象
  • javascript使用Promise对象实现异步编程【javascript】
  • javascript使用Promise对象实现异步编程【javascript】 | javascript使用Promise对象实现异步编程【javascript】 ...