你的位置:首页 > 软件开发 > Java > ES6笔记(7)

ES6笔记(7)

发布时间:2016-09-28 17:00:31
系列文章 -- ES6笔记系列 很久很久以前,在做Node.js聊天室,使用MongoDB数据服务的时候就遇到了多重回调嵌套导致代码混乱的问题。JS异步编程有利有弊,Promise的出现,改善了这一格局,让异步编程表现出类似“同步式代码&rdquo ...

ES6笔记(7)

 

系列文章 -- ES6笔记系列

 

很久很久以前,在做Node.js聊天室,使用MongoDB数据服务的时候就遇到了多重回调嵌套导致代码混乱的问题。

JS异步编程有利有弊,Promise的出现,改善了这一格局,让异步编程表现出类似“同步式代码”的形式,更好地体现了它的价值。

 

一、基本概念

1. Promises/A+规范

Promise是一种异步编程的解决方案,本质来说其实它是一种规范,Promises/A+规范

根据规范的定义,一个Promise对象应该至少有以下的基本特点

三个状态

Promise有三个状态:Pending(进行中)、Resolved或Fulfilled(已完成)、Rejected(已失败)

其中:Pending为Promise的初始状态;当Resolved成功时,会调用onFulfilled方法;当Rejected失败时,会调用onRejected方法

并且:状态只能从Pending转换为Resolved状态,或者从Pending转换为Rejected状态,不存在其他状态间的转换

Then方法

Promise必须提供一个then方法,用以访问当前值、最终的返回值以及失败的原因

最基本的then方法接受两个函数参数 promise.then(onFulfilled, onReject),对应于状态变化到Resolved和Rejected时的函数调用

 

2. Promise简单的实现

基于Promises/A+中规范的要求,可以自行实现一个基本的promise对象

可参考 一步一步实现一个Promise

二、基本使用

1. 使用相关插件

近年来,已经出现了很多Promise异步编程的插件,我们可以使用这些插件,常见的有:

  • Q
  • when
  • RSVP.js
  • jQuery的Deferred

 

例如使用jQuery新版Ajax模块内置的Deferred使用到了Promise,我们可以直接这样调用

// 回调函数的方式$.get('url', function(rs) {  rs = JSON.parse(rs);});// Promise的形式$.get('url').success(function(rs) {  rs = JSON.parse(rs);})

 

海外公司注册、海外银行开户、跨境平台代入驻、VAT、EPR等知识和在线办理:https://www.xlkjsw.com

原标题:ES6笔记(7)

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录