promise原理是什么
发表于:2025-02-23 作者:千家信息网编辑
千家信息网最后更新 2025年02月23日,本篇文章为大家展示了promise原理是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、 promise应用场景1 解决回调地狱比如我们经常可能需要异步
千家信息网最后更新 2025年02月23日promise原理是什么
本篇文章为大家展示了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原理是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
状态
函数
方法
原理
成功
两个
代码
内容
场景
实例
对象
就是
技能
数据
知识
面的
形参
应用
可怕
复杂
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
无线网络安全实验手册答案
5g时代学网络技术
网络技术有限公司好不好
为什么登不上黑魂三服务器了
arcgis时空数据库
守住网络安全管理
识别车牌号码的软件开发包
服务器管理培训心得
家用邮箱服务器
目前最成熟的网络安全技术是什么
携智网络技术北京有限公司
存在同名数据库是什么意思
数据库基本结构分为几层
计算机网络安全隐患
网络安全预防措施及处理办法
工信部网络安全处张鑫
数据库hash查找
江西java微服务架构数据库
计算机网络安全第11章
从服务器拆下来的硬盘怎么读数据
开源视频会议服务器安全吗
云服务器centos搭建博客
软件开发服务是否免税
db2数据库缓冲池命中率
梦三国连接服务器失败
服务软件开发热线
新乡知淘网络技术
5g嵌入式软件开发前景
软件开发和自动化
access数据库百分比函数