美文网首页
Promise的封装

Promise的封装

作者: 不期而遇_3491 | 来源:发表于2018-11-09 15:55 被阅读0次

在JavaScript的世界中,所有代码都是单线程执行的。

由于这个“缺陷”,导致JavaScript的所有网络操作,浏览器事件,都必须是异步执行。异步执行可以用回调函数实现:

Promise对象代表一个异步操作,有三种状态:

pending 进行中

fulfilled 已成功

rejected 已失败

对象的状态不受外界影响,一旦状态改变,就不会再变

Promise对象的状态改变,只有两种可能:

pending => fulfilled

pending => rejected

---------------------

function getAjax(type, url, data) {

return new Promise(function(resolve, reject) {

var xhr = null

if (window.XMLHttpRequest) {

xhr = new XMLHttpRequest();

} else {

xhr = new ActiveXObject("Microsoft.XMLHTTP");

}

xhr.open(type, url, true);

xhr.onreadystatechange = function() {

if (xhr.readyState == 4 && xhr.status == 200) {

resolve(JSON.parse(xhr.responseText));

} else {

reject(xhr)

}

}

if (type == 'GET') {

xhr.send()

} else {

xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");

xhr.send(formatParams(data));

}

})

function formatParams(data) {

var arr = [];

for (var name in data) {

arr.push(name + '=' + data[name]);

}

return arr.join("&");

}

}

请求完成后,可以用.then来执行成功后的回调函数

用.catch来执行失败后的回调函数

Promise.all([p1, p2]).then(function(results){console.log(results);// 获得一个Array: ['P1', 'P2']});

varp1 =newPromise(function(resolve, reject){setTimeout(resolve,500,'P1');});

varp2 =newPromise(function(resolve, reject){setTimeout(resolve,600,'P2');});

Promise.race([p1, p2]).then(function(result){console.log(result);// 'P1'});

如上,当需要多个异步都执行完毕以后执行可以用.all.then的回调函数执行

当需要其中的一个异步操作执行完毕以后就可以,可以用.race

相关文章

网友评论

      本文标题:Promise的封装

      本文链接:https://www.haomeiwen.com/subject/rlroxqtx.html