您的位置 首页 技术

promise原理是什么

一、promise应用场景 1.解决回调地狱 比如我们经常可能需要异步请求一个数据之后作为下一个异步操作的入参 getData(function(a){ getMoreData(a…

一、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;

更多常见问题,敬请访问PHP中文网。

以上就是promise原理是什么的详细内容,更多请关注24课堂在线网其它相关文章!

本文来自网络,不代表24小时课堂在线立场,转载请注明出处:https://www.24ketang.cn/29784.html

为您推荐

返回顶部