javascript异步编程代码书写规范Promise学习笔记


Posted in Javascript onFebruary 11, 2015

最近工作轻松了点,想起了以前总是看到的一个单词promise,于是耐心下来学习了一下。

一:Promise是什么?为什么会有这个东西?

首先说明,Promise是为了解决javascript异步编程时候代码书写的方式产生的。
随着javascript的发展,异步的场景越来越多。前端有AJAX,setTimeout等,后端Node异步更多。按照传统的做法,那么就是各种回调嵌回调。代码可以把人绕晕。
这个时候,CommonJS社区提出了一个叫做Promise/A+的规范,这个规范定义了如何书写异步代码,包括使用when/then/resolve等来组织异步的代码。
这个规范由于很优雅,所以相继就有很多人实现了这个规范,其中包括 浏览器原生支持的Promise(), jQuery里面的deferred,when.js等。
因为这几个库都符合该规范,所以学习一个也就可以了。我主要学习了jQuery的deferred,所以本文主要讲讲这个实现。
 
二:jQuery的deferred

首先,关于deferred对象,阮一峰老师有篇文章写的很详细了,地址点这。建议可以先看看他的那篇文章,再继续往下看。
上面说过,promise是为了解决异步(比如ajax)的,那么我们来对比下他们的区别。
经典的jQuery的AJAX的写法是

$.ajax({

    type: "get",

    url: "",

    success: function () {},

    error; function () {}

});

其中success和error参数便是成功/失败时候的回调函数。 

而现在jQuery的AJAX写法成了

$.ajax({

    type; "get",

    url: ""

}).done(function () {}).fail(function () {});

其中成功后会调用done里面的函数,失败便会调用fail里面的函数。 

看到这里也许你就会有疑问了,done/fail这些方法是哪个对象上的?$.ajax()返回了什么对象,为什么有这两个方法?
答案就在下面介绍的Deferred对象。

jQuery提供了一种新的类型Deferred。通过$.Deferred()来生成。例如

var def = $.Deferred();

这个def继承了很多方法,有done/fail/resolve/reject等。
所以这里我们也就知道,上面$.ajax()其实返回的也就是这个对象。
 
deferred对象有很多方法,这里介绍几种常用的,更多的可以参考 API
 
首先自然是生成一个def对象。这里有很多方法,比如:

var def = $.Deferred();    // 自己生成

$.ajax({});    // ajax方法返回的也是def对象

$.when();    // when方法也会返回一个def对象

这里,$.when()可以单独讲讲,这个方法通常接收一个或多个deferred对象,然后根据这些deferred对象的状态情况,来决定$.when()返回的对象的状态。其中有个使用场景就是多个ajax请求,如果其中一个失败就都算失败,那么便可以在$.when()中传入多个ajax方法,例如$.when($.ajax(), $.ajax())。然后$.when会返回一个def对象(根据这两个请求结果的来判断)。
 
接着得到了def对象,便有了一系列改变这个对象状态的方法

def.resolve();    // 把def对象设置成已经完成,然后便会立刻执行绑定在def.done()里面的函数。

def.reject();    // 把def对象设置成已经失败,然后便会立刻执行绑定在def.fail()里面的函数。

def.notify();    // def对象执行中,对应的回调是def.progress()。

紧接着是设置回调的方法,顺序和上面的对应,也就是什么状态会调用到什么回调

def.done();    // 对应def.resolve();

def.fail();    // 对应def.reject();

def.progress();    // 对应 def.notify();

// 特殊的

def.always();    // 成功或者失败都会调用

def.then();    // 接受多个函数,按顺序依次是成功(done),失败(fail)和进行中(progress)

其实到这里位置,deferred对象的用法也就差不多了。不过jQuery还提供了几个API

// 检查当前状态类

def.isRejected();

def.isResolved();

def.state();

这几个api顾名思义,就不具体讲了,具体可以查看上面给的jQuery API文档。
 
还有一个方法,就是有时候我们希望给外部一个def对象,然后这个对象可以设置各种状态的回调,但是不能改变它的状态,那么就可以用

def.promise();

返回一个promiese对象,是deferred对象的子集,可以用done/fail等方法,没有resolve/reject等方法,主要是为了保护不让外部去修改def对象的状态。 

至此,关于promise已经全部讲完,大家现在就可以把它用在自己的项目中了,另外提早给大家拜个早年,祝大家羊年洋洋得意^ ^。

Javascript 相关文章推荐
不用ajax实现点击文字即可编辑的方法
Dec 16 Javascript
js表数据排序 sort table data
Feb 18 Javascript
javascript URL锚点取值方法
Feb 25 Javascript
ASP.NET jQuery 实例17 通过使用jQuery validation插件校验ListBox
Feb 03 Javascript
js取两个数组的交集|差集|并集|补集|去重示例代码
Aug 07 Javascript
SWFUpload多文件上传及文件个数限制的方法
May 31 Javascript
JS实现的打字机效果完整实例
Jun 20 Javascript
基于SpringMVC+Bootstrap+DataTables实现表格服务端分页、模糊查询
Oct 30 Javascript
Vue2.0 实现移动端图片上传功能
May 30 Javascript
解决koa2 ctx.render is not a function报错问题
Aug 07 Javascript
vue实现评价星星功能
Jun 30 Javascript
ES6中的类(Class)示例详解
Dec 09 Javascript
jquery实现动态操作select选中
Feb 11 #Javascript
JS操作HTML自定义属性的方法
Feb 10 #Javascript
jQuery制作仿Mac Lion OS滚动条效果
Feb 10 #Javascript
jQuery扁平化风格下拉框美化插件FancySelect使用指南
Feb 10 #Javascript
javascript中定义类的方法详解
Feb 10 #Javascript
JavaScript判断浏览器类型的方法
Feb 10 #Javascript
javascript定时器完整实例
Feb 10 #Javascript
You might like
PHP动态图像的创建
2006/10/09 PHP
PHP的SQL注入实现(测试代码安全不错)
2011/02/27 PHP
destoon供应信息title调用出公司名称的方法
2014/08/22 PHP
JavaScript Object的extend是一个常用的功能
2009/12/02 Javascript
jquery 学习之一 对象访问
2010/11/23 Javascript
HTML中的setCapture和releaseCapture使用介绍
2012/03/21 Javascript
$(document).ready(function() {})不执行初始化脚本
2014/06/19 Javascript
jQuery制作简洁的图片轮播效果
2015/04/03 Javascript
IE7浏览器窗口大小改变事件执行多次bug及IE6/IE7/IE8下resize问题
2015/08/21 Javascript
JS简单实现浮动窗口效果示例
2016/09/07 Javascript
js实现功能比较全面的全选和多选
2017/03/02 Javascript
微信小程序中显示html格式内容的方法
2017/04/25 Javascript
详解webpack解惑:require的五种用法
2017/06/09 Javascript
微信小程序wepy框架笔记小结
2018/08/08 Javascript
原生JS无缝滑动轮播图
2019/10/22 Javascript
JS实现移动端可折叠导航菜单(现代都市风)
2020/07/07 Javascript
在漏洞利用Python代码真的很爽
2007/08/26 Python
python制作小说爬虫实录
2017/08/14 Python
python实现大学人员管理系统
2019/10/25 Python
Python通过类的组合模拟街道红绿灯
2020/09/16 Python
详解Anaconda 的安装教程
2020/09/23 Python
CSS3实现滚动条动画效果代码分享
2016/08/03 HTML / CSS
英国家庭家具、照明和花园家具购物网站:Furniture123
2018/12/31 全球购物
英国蛋糕装饰用品一站式商店:Craft Company
2019/03/18 全球购物
一个J2EE项目团队的主要人员组成是什么
2012/06/04 面试题
校长岗位职责
2013/11/26 职场文书
采购部部门职责
2013/12/15 职场文书
会计主管岗位职责
2014/01/03 职场文书
《一个小村庄的故事》教学反思
2014/04/13 职场文书
初中成绩单评语
2014/12/29 职场文书
美丽心灵观后感
2015/06/01 职场文书
python正则表达式re.search()的基本使用教程
2021/05/21 Python
go xorm框架的使用
2021/05/22 Golang
postgreSQL数据库基础知识介绍
2022/04/12 PostgreSQL
apache ftpserver搭建ftp服务器
2022/05/20 Servers
Android 中的类文件和类加载器详情
2022/06/05 Java/Android