本篇文章为大家展示了promise原理是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
一、 promise应用场景
1 解决回调地狱
比如我们经常可能需要异步请求一个数据之后作为下一个异步操作的入参
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));
2 promise 可以实现在多个请求发送完成后 再得到或者处理某个结果
// 两个数据都回来之后再进行操作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);});
二、promise原理实现
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;
上述内容就是promise原理是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。