直观的链式回调 MyPromise

本文详细介绍了如何从零开始实现一个简易版的Promise对象,并通过具体的示例展示了其使用方法。作者创建了一个名为MyPromise的函数,该函数接受一个执行器函数作为参数,执行器函数接收resolve和error两个回调函数。在MyPromise内部,定义了then方法用于链式调用,处理成功和失败的回调。最后,通过test函数返回一个MyPromise实例,演示了如何使用自定义的Promise进行异步操作。

 

function MyPromise(fun) {
	let self = this;
	self.then = function (resolve, error) {
		resolve&&resolve(self.value);
		error&&error(self.errValue);
		return this;
	}

	function resolve (value) {
		self.value = value;
	}

	function error (value) {
		self.errValue = value;
	}

	fun(resolve, error);
}

function test () {
	return new MyPromise(function(resolve,error){
		resolve("我是个正确值");
		error('我是个错误值');
	});
}

test().then(function(result){
	console.info('result = ', result)
}).then(function(result){
	console.info('result = ', result)
});

 

转载于:https://www.cnblogs.com/SATinnovation/p/10131539.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值