赞
踩
- getData(function(a){
- getMoreData(a, function(b){
- getMoreData(b, function(c){
- getMoreData(c, function(d){
- getMoreData(d, function(e){
- ...
- });
- });
- });
- });
- });
可以发现上面的代码看起来是非常可怕的,层层嵌套,如果在加上复杂的逻辑判断,代码可读性会变得非常差。
但是你如果使用promise的话:
- function getData() {
- return new Promise(function (resolve, reject) {
- resolve(1);
- });
- }
- function getMoreData(arg) {
- return new Promise(function (resolve, reject) {
- resolve(arg + 10);
- });
- }
- getData().then(function (a) {
- console.log(a); // 1
- return getMoreData(a);
- }).then(function (b) {
- console.log(b); // 11
- })

把上面代码再简洁点儿
- getData()
- .then(a => getMoreData(a))
- .then(b => console.log(b));
- // 两个数据都回来之后再进行操作
- let fs = require('fs');
- fs.readFile('./1.txt', 'utf8', function (err, data) {
- console.log(data);
- })
- fs.readFile('./2.txt', 'utf8', function (err, data) {
- console.log(data);
- })
使用promise的话就可以实现:
- let fs = require('fs');
- function read(url){
- return new Promise(function(resolve,reject){
- fs.readFile(url,'utf8',function(err,data){
- if(err)reject(err);
- resolve(data);
- })
- })
- }
- Promise.all([read('1.txt'),read('2.txt')]).then(data=>{
- console.log(data);
- },err=>{
- console.log(err);
- });
1.最简单的实现
基于上面的应用场景发现promise
可以有三种状态,分别是pedding
、Fulfilled
、 Rejected
。
Pending Promise
对象实例创建时候的初始状态Fulfilled
可以理解为成功的状态Rejected
可以理解为失败的状态
Promise
实例需要给Promise
构造函数传入一个函数。传入的函数需要有两个形参,两个形参都是function
类型的参数。分别是resolve
和reject
。Promise
上还有then
方法,then
方法就是用来指定Promise
对象的状态改变时确定执行的操作,resolve
时执行第一个函数(onFulfilled),reject
时执行第二个函数(onRejected)resolve
时便不能再变为reject
,反之同理。基于上面描述我们可以实现一个这样的promise
- function Promise(executor){ //executor执行器
- let self = this;
- self.status = 'pending'; //等待态
- self.value = undefined; // 表示当前成功的值
- self.reason = undefined; // 表示是失败的值
- function resolve(value){ // 成功的方法
- if(self.status === 'pending'){
- self.status = 'resolved';
- self.value = value;
- }
- }
- function reject(reason){ //失败的方法
- if(self.status === 'pending'){
- self.status = 'rejected';
- self.reason = reason;
- }
- }
- executor(resolve,reject);
- }
-
- Promise.prototype.then = function(onFufiled,onRejected){
- let self = this;
- if(self.status === 'resolved'){
- onFufiled(self.value);
- }
- if(self.status === 'rejected'){
- onRejected(self.reason);
- }
- }
- module.exports = Promise;

参考文献:
https://www.cnblogs.com/greatluoluo/p/6288931.html
转自https://www.jianshu.com/p/fc5030e725ae
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。