简易promise的实现(二)
上一章中我们遇到了两个问题
1.异步调用顺序的问题
2.then返回一个promise的问题
思考
如果控制异步回调的顺序?
因为异步操的时间作我们无法控制,但是我们只需要按顺序执行回调函数就好了
也就是说
then里面的回调,我们等调用 resolve方法之后(确保异步操作完成),再来执行
操作
用一个变量nextResolve 来保存then的 回调函数
放在resolve之后调用
function MyPromise(fn) {
var res = null,
callback = null,
nextResolve = null;
function resolve(val) {
if(typeof(callback) === 'function'){
res = callback(val);
}
nextResolve(res);
}
function reject(val){
if(typeof(callback) === 'function'){
res = callback(val);
}
nextResolve
}
this.then = function (cb) {
callback = cb;
return new MyPromise(function(resolve,reject){
nextResolve = resolve;
})
};
fn(resolve,reject);
}
结果是

是我们要的结果。
现在到第二个问题
如果返回的是一个promise呢? 下面这种是我们的连续异步操作
http('www.123.com').then(function(res){
console.log(res)
return http('www.456.com');
}).then(function(res){
console.log(res)
})
直接把 promise对象返回了,不是promise执行之后的值

这个时候我们要的是 www.456.com
也就是说我们要执行 then方法,才能得到 www.456.com
现在我们只要判断,如果是返回一个promise对象,我们就执行他的resolve方法 就能拿到它回调的值了。
注意 return
function MyPromise(fn) {
var res = null,
callback = null,
nextResolve = null;
function resolve(val) {
if(typeof(callback) === 'function'){
res = callback(val);
}
if(res && res instanceof MyPromise){
var newThen = res.then
newThen.call(res,nextResolve);
return;
}
if(typeof(nextResolve) === 'function'){
nextResolve(res);
}
}
function reject(val){
if(typeof(callback) === 'function'){
res = callback(val);
}
nextResolve
}
this.then = function (cb) {
callback = cb;
return new MyPromise(function(resolve,reject){
nextResolve = resolve;
})
};
fn(resolve,reject);
}

成功返回
下一章我们介绍 ,reject 和catch的写法
简易promise的实现(二)的更多相关文章
- 简易promise
<!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...
- 实现简易Promise
概述 异步编程离不开promise, async, 事件响应这些东西,为了更好地异步编程,我打算探究一下promise的实现原理,方法是自己实现一个简易的promise. 根据promise mdn上 ...
- django 开发简易博客(二)
这一节我们来了解模板和视图.URL的使用. 一.使用模板 在blog目录中新建templates文件夹,在templates文件夹下新建base.html文件.目录结构如下 templates/ ba ...
- 一步一步实现基于Task的Promise库(二)all和any方法的设计和实现
在上一篇中我们已经初步完成了Task类,如果仅仅是这些,那么没有多大意义,因为网上这类js库有很多,现在我们来些更复杂的使用场景. 如果我们现在有这样一个需求:我们要先读取aa.txt的内容,然后去后 ...
- 简易promise的实现(一)
code 最近在思考promise的实现原理 于是准备自己写一个简单的demo 一开始想到的问题有两个 1.链式调用 2.异步顺序执行 -------------------------------- ...
- 基于Java的简易表达式解析工具(二)
之前简单的介绍了这个基于Java表达式解析工具,现在把代码分享给大家,希望帮助到有需要的人们,这个分享代码中依赖了一些其他的类,这些类大家可以根据自己的情况进行导入,无非就是写字符串处理工具类,日期处 ...
- C 实现一个简易的Http服务器 (二)
正文 - 直接搞起 C 实现一个简易的Http服务器 很久以前写过一个简易的http服务器, 后面和一个朋友交流, 反思后发现问题不少.在这里简单搞一下. 让其更加简单去表现httpd本质, 弱化协议 ...
- deferred对象和promise对象(二)---deferred对象
早上醒来,继续讨论deferred对象和primise对象. deferred对象的的方法: 1.$.Deferred()-----生成一个deferred对象 2.deferred.done()-- ...
- caffe简易上手指南(二)—— 训练我们自己的数据
训练我们自己的数据 本篇继续之前的教程,下面我们尝试使用别人定义好的网络,来训练我们自己的网络. 1.准备数据 首先很重要的一点,我们需要准备若干种不同类型的图片进行分类.这里我选择从ImageNet ...
随机推荐
- vue-微信支付or支付宝支付片段
<ulclass="way_list"> <li v-if="!isWeixinBrowser" class="group al ...
- Django web编程3 -- 创建用户账户
我们将建立一个用户注册和身份验证系统,让用户能够注册账户,进而登录和注销.我们将创建一个新的应用程序,其中包含与处理用户账户相关的所有功能.我们还将对模型Topic 稍做修改,让每个主题都归属于特定用 ...
- 编写高质量的Python代码系列(八)之部署
Python提供了一些工具,使我们可以把软件部署到不同的环境中.它也提供了一些模块,令开发者可以把程序编写的更加健壮.本章讲解如何使用Python调试.优化并测试程序,以提升其质量与性能. 第五十四条 ...
- 从Random Walk谈到Bacterial foraging optimization algorithm(BFOA),再谈到Ramdom Walk Graph Segmentation图分割算法
1. 从细菌的趋化性谈起 0x1:物质化学浓度梯度 类似于概率分布中概率密度的概念.在溶液中存在不同的浓度区域. 如放一颗糖在水盆里,糖慢慢溶于水,糖附近的水含糖量比远离糖的水含糖量要高,也就是糖附近 ...
- 2019秋招Java面经(未完待续)
2019秋招Java面经(凭记忆回忆, 可能不准) 随着我们从大三升到大四...秋招也开始了. 秋招进行的还比较顺利, 刚开始没几天, 我的秋招就结束了. 到现在我玩了差不多十多天了, 总想着总结一下 ...
- 对于Sobel算子的学习
本来想说很多目前对于 Sobel 算子的认识,但最终还是觉得对于其掌握程度太低,没有一个系统的理解,远不足以写博客,但为了12月不至于零输出,还是决定把自己学习过程中找到的相关资料进行分享. 等到一月 ...
- day21双下方法,源码相关,异常处理
#!/usr/bin/env python# -*- coding:utf-8 -*- # 1.列举你了解的面向对象中的特殊成员,并为每个写代码示例.'''__init__初始化:class A: d ...
- docker学习------registry可视化的实现
1.Harbor的发现 之前一直在使用registry,但docker pull下来的基础镜像并没用携带UI界面,所以查找了一波开源工具,发现了Harbor这一工具,下面对工具进行一个学习. 2.部 ...
- XXX系统项目分析
目标: 实现网上需求征集与审核. 好处: (1)网上填报不受时间和地点限制: (2)流程简单明确,节省人力物力: (3)信息存储,查询,筛选远比纸质材料方便: (4)方便统计,分析数据: 度量标准: ...
- Linux下删除乱码文件
删除乱码文件 一些文件乱码