蒙狼科技logo
设为首页| 联系我们
咨询热线: 13917498722
  您的位置: 首页 > 网站资讯 > 使用Promise模式来简化javascript的异步回调

使用Promise模式来简化javascript的异步回调

发布日期:2017/6/19

百度权重查询 站长交易 友情链接交换 网站监控 服务器监控 seo监控

网页的交互越来越复杂,javascript 的异步操作也随之越来越多。如常见的 ajax 请求,需要在请求完成时响应操作,请求通常是异步的,请求的过程中用户还能进行其他的操作,不会对页面进行壅塞,这种异步的交互效果对用户来说是挺有友爱的。但是对于开发者来说,要大量处理这种操作,就很不友爱了。异步请求完成的操作必须预先定义在回调函数中,等到请求完成就必须调用这个函数。这种非线性的异步编程体例会让开发者很不适应,同时也带来了诸多的未便,增添了代码的耦合度和复杂性,代码的组织上也会很不优雅,大大降低了代码的可维护性。情况再复杂点,假如一个操作要等到多个异步 ajax 请求的完成才能进行,就会出现回调函数嵌套的情况,假如需要嵌套好几层,那你就只能自求多福了。

先看看下面这个常见的异步函数。

var showMsg = function(){

setTimeout(function(){

alert( ‘hello’ );

}, 5000 );

};

假如要给该函数添加回调,通常会这么干。

var showMsg = function( callback ){

setTimeout(function(){

alert( ‘hello’ );

// 此处添加回调

callback();

}, 5000 );

};

假如是使用 easy.js 的 Promise,添加回调的方法就会优雅多了,前提是需要将原函数封装成一个 promise 实例。

var showMsg = function(){

// 构造promise实例

var promise = new E.Promise();

setTimeout(function(){

alert( ‘hello’ );

// 改变promise的状况

promise.resolve( ‘done’ );

}, 5000 );

// 返回promise实例

return promise;

};

将一个通俗的函数封装成一个 promise 实例,有3个关键步骤,步是在函数内部构造一个 promise 实例,第二步是部署函数执行完去改变 promise 的状况为已完成,第三步就是返回这个 promise 实例。每个 promise 实例都有3种状况,分别为 pending(未完成)、resolved(已完成,成功)、rejected(已拒绝,失败)。下面再来看看如何添加回调。

showMsg().then(function( str ){

// 回调添加到这里来了

callback( str );

});

这样就将回调函数和原来的异步函数彻底的星散了,从代码组织上看,优雅了许多。resolve 接受一个参数,该参数就可以轻松实现将数据传送给使用 then 方法添加的回调中。

对于 ajax 请求,easy.js 直接将 ajax 方法封装成了 promise 对象,可以直接添加 then 方法往返调。

E.ajax({

url : ‘test1.php’,

type : ‘GET’

})

then(function(){

// 添加请求成功的回调

}, function(){

// 添加请求失败的回调

});

then 方法接受2个函数作为参数,个函数是已完成的回调,第二个就是已失败的回调。

假如有上面提到的多个 ajax 请求的情况呢?那么就要用到 when 这个方法了。该方法可以接受多个 promise 实例作为参数。

var requests = E.when(E.ajax({

url : ‘test1.php’,

type : ‘GET’

}), E.ajax({

url : ‘test2.php’,

type : ‘GET’

}));

requests.then(function( arg1, arg2 ){

console.log( ‘success:’ + arg1[0] + arg2[0] );

}, function( arg1, arg2 ){

console.log( ‘failure:’ + arg1 + arg2 );

});

when 方法是将多个 promise 实例存到一个数组中,等到该数组的所有 promise 实例都是已完成状况才去执行已完成的回调,一旦有一个实例是已拒绝的状况,则立即执行已拒绝的回调。

Promise 模式是 CommonJS 的规范之一。许多主流的 javascript 库都有响应的实现,如 jQuery 和 Dojo 中,都有 Deferred 去实现这些功能。在这里照旧要吐槽下 jQuery 的 Deferred,撇开其内部使用,这应该用户使用率好低的一个模块了,这和其较复杂的使用体例有一定的关系。

假如你想深入的研究 easy.js 的 promise 源码,可以查看点击这儿的链接。

文章来源:夜雨带刀博客





其他相关文章
  • 苹果Swift语言开源了!附下载地址
  • 网站建设之如何提高网站权重?
  • 对IP和子网掩码的一点粗浅熟悉
  • 叱咤风云!20个史诗级的大屏全景网站设计
  • 网络推广渠道有哪些
  • 网站打不开的缘故原由有解决方法了




  • 企业网站后台使用
    购物网站后台使用
    网站产品图片的处理



    农业银行支付
    建设银行支付
    邮政储蓄银行支付



    企业网站建设
    整站建设
    购物网站



    企业网站建设建议
    注册适合自己的域名
    什么是虚拟主机




    售前咨询QQ: 838821345
    售后服务QQ: 464698733
    应急手机:13917498722


    微信扫一扫
    添加24小时微信客服


    邮箱:lang@MENGL.CN
    地址:上海宝山区城银路555弄2号楼3楼
    ICP备案:沪ICP备12042844号-3
     沪公网安备:31011402002917号
    做网站 | 企业网站建设 | 上海做网站 | 企业网站制作 | 做网站的公司 | 关于蒙狼 | 整站建设 | 购物网站 | 企业网络营销 | 成功案例 | 加盟代理 | 在线订单
    服务区域: 临港新区做网站 徐汇做网站 闵行做网站 长宁做网站 虹口做网站 黄浦做网站 卢湾做网站 静安做网站 浦东做网站 杨浦做网站 普陀做网站 闸北做网站 宝山做网站 嘉定做网站 松江做网站 昆山做网站
    Copyright 2012-2025 上海蒙狼网络科技有限公司 WWW.MENGL.CN All Rights Reserved