💎一站式轻松地调用各大LLM模型接口,支持GPT4、智谱、星火、月之暗面及文生图 广告
## 题目 ### 简单手写实现promise ``` // 简易版本的promise // 第一步: 列出三大块 this.then resolve/reject fn(resolve,reject) // 第二步: this.then负责注册所有的函数 resolve/reject负责执行所有的函数 // 第三步: 在resolve/reject里面要加上setTimeout 防止还没进行then注册 就直接执行resolve了 // 第四步: resolve/reject里面要返回this 这样就可以链式调用了 // 第五步: 三个状态的管理 pending fulfilled rejected // promise的链式调用 在then里面return一个promise 这样才能then里面加上异步函数 // 加上了catch function PromiseM(fn) { var value = null; var callbacks = []; //加入状态 //为了解决在Promise异步操作成功之后调用的then注册的回调不会执行的问题 var state = 'pending'; var _this = this; //注册所有的回调函数 this.then = function(fulfilled, rejected) { //如果想链式promise 那就要在这边return一个new Promise return new PromiseM(function(resolv, rejec) { //异常处理 try { if (state == 'pending') { callbacks.push(fulfilled); //实现链式调用 return; } if (state == 'fulfilled') { var data = fulfilled(value); //为了能让两个promise连接起来 resolv(data); return; } if (state == 'rejected') { var data = rejected(value); //为了能让两个promise连接起来 resolv(data); return; } } catch(e) { _this. catch(e); } }); } //执行所有的回调函数 function resolve(valueNew) { value = valueNew; state = 'fulfilled'; execute(); } //执行所有的回调函数 function reject(valueNew) { value = valueNew; state = 'rejected'; execute(); } function execute() { //加入延时机制 //防止promise里面有同步函数 导致resolve先执行 then还没注册上函数 setTimeout(function() { callbacks.forEach(function(cb) { value = cb(value); }); }, 0); } this.catch = function(e) { console.log(JSON.stringify(e)); } //经典 实现异步回调 fn(resolve, reject); } ```