《你不知道的Javascript--中卷 学习总结》(异步、promise)
栏目: JavaScript · 发布时间: 5年前
内容简介:1、任何时候,只要把一段代码包装成一个函数,并指定它在响应某个事件(2、多数情况下,代码在开发者工具的控制台中输出的对象表示与期望是一致的。但是, 下面这段代码运行的时候,浏览器可能会认为需要把控制台 I/O 延迟到后台,在这种情况下, 等到浏览器控制台输出对象内容时,a.index++ 可能已经执行,因此会显示 { index: 2 }。3、并发交互模式
1、任何时候,只要把一段代码包装成一个函数,并指定它在响应某个事件( 定时器、鼠标点 击、Ajax 响应等
)时执行,你就是在代码中创建了一个将来执行的块。
2、多数情况下,代码在开发者 工具 的控制台中输出的对象表示与期望是一致的。但是, 下面这段代码运行的时候,浏览器可能会认为需要把控制台 I/O 延迟到后台,在这种情况下, 等到浏览器控制台输出对象内容时,a.index++ 可能已经执行,因此会显示 { index: 2 }。
var a = { index: 1 }; // 然后 console.log( a ); // 2 // 再然后 a.index++; 复制代码
3、并发交互模式
- 根据返回的特性标识处理,根据不同的url来存放在数组的不同位置。
var res = []; function response(data) { if (data.url == "http://some.url.1") { res[0] = data; } else if (data.url == "http://some.url.2") { res[1] = data; } } // ajax(..)是某个库中提供的某个Ajax函数 ajax( "http://some.url.1", response ); ajax( "http://some.url.2", response ); 复制代码
- 两个值全部存在,在进行函数调用(门闩)
var a, b; function foo(x) { a = x * 2; if (a && b) { baz(); } } function bar(y) { b = y * 2; if (a && b) { baz(); } } function baz() { console.log( a + b ); } // ajax(..)是某个库中的某个Ajax函数 ajax( "http://some.url.1", foo ); ajax( "http://some.url.2", bar ); 复制代码
- 只要其中一个执行
var a; function foo(x) { if (!a) { a = x * 2; baz(); } } function bar(x) { if (!a) { a = x / 2; baz(); } } function baz() { console.log( a ); } // ajax(..)是某个库中的某个Ajax函数 ajax( "http://some.url.1", foo ); ajax( "http://some.url.2", bar ); 复制代码
Promise
检测promise类型(检测是否定义thenable)
if ( p !== null && ( typeof p === "object" || typeof p === "function" ) && typeof p.then === "function" ){ // 假定这是一个thenable! } else { // 不是thenable } 复制代码
Promise API 概述
- new Promise(..) 构造器
1、有启示性的构造器 Promise(..) 必须和 new 一起使用,并且必须提供一个函数回调。这个 回调是 同步的
或 立即调用
的。这个函数接受两个函数回调,用以支持 promise 的决议。通 常我们把这两个函数称为 resolve(..)
和 reject(..)
var p = new Promise( function(resolve,reject){ // resolve(..)用于决议/完成这个promise // reject(..)用于拒绝这个promise } ); 复制代码
2、reject(..) 就是拒绝这个 promise;但 resolve(..) 既可能完成 promise,也可能拒绝,要 根据传入参数而定。如果传给 resolve(..) 的是一个 非 Promise
、 非 thenable 的立即值
,这 个 promise 就会用这个值 完成
。
3、如果传给 resolve(..) 的是一个真正的 Promise 或 thenable 值,这个值就会被递归展 开,并且(要构造的)promise 将取用其最终决议值或状态。
- Promise.resolve(..) 和 Promise.reject(..)
1、创建一个已被拒绝的 Promise 的快捷方式是使用 Promise.reject(..),所以以下两个 promise 是等价的
var p1 = new Promise( function(resolve,reject){ reject( "Oops" ); } ); var p2 = Promise.reject( "Oops" ); 复制代码
2、Promise.resolve(..) 会展开 thenable 值(前面已多次介绍)。在这种情况 下,返回的 Promise 采用传入的这个 thenable 的最终决议值,可能是 完成
,也可能是 拒绝
var fulfilledTh = { then: function(cb) { cb( 42 ); } }; var rejectedTh = { then: function(cb,errCb) { errCb( "Oops" ); } }; var p1 = Promise.resolve( fulfilledTh ); var p2 = Promise.resolve( rejectedTh ); // p1是完成的promise // p2是拒绝的promise 复制代码
3、如果传入的是真正的 Promise,Promise.resolve(..) 什么都不会做,只会直接 把这个值返回
- then(..) 和 catch(..)
1、每个 Promise 实例(不是 Promise API 命名空间)都有 then(..) 和 catch(..) 方法,通过 这两个方法可以为这个 Promise 注册完成和拒绝处理函数
2、then(..) 接受一个或两个参数:第一个用于完成回调,第二个用于拒绝回调。如果两者中 的任何一个被省略或者作为非函数值传入的话,就会替换为相应的默认回调。默认完成回 调只是把消息传递下去,而默认拒绝回调则只是重新抛出(传播)其接收到的出错原因。
3、catch(..) 只接受一个拒绝回调作为参数,并自动替换默认完成 回调。换句话说,它等价于 then(null,..)
p.then( fulfilled ); p.then( fulfilled, rejected ); p.catch( rejected ); // 或者p.then( null, rejected ) 复制代码
4、then(..) 和 catch(..) 也会创建并返回一个新的 promise,这个 promise 可以用于实现 Promise 链式流程控制。如果完成或拒绝回调中抛出异常,返回的 promise 是被拒绝的。如 果任意一个回调返回非 Promise、非 thenable 的立即值,这个值会被用作返回 promise 的完 成值。如果完成处理函数返回一个 promise 或 thenable,那么这个值会被展开,并作为返回 promise 的决议值。
- Promise.all([ .. ]) 和 Promise.race([ .. ])
1、ES6PromiseAPI静态辅助函数Promise.all([ .. ])和Promise.race([ .. ])都会创建一 个 Promise 作为它们的返回值。这个 promise 的决议完全由传入的 promise 数组控制。
2、对Promise.all([ .. ])来说,只有传入的所有promise都完成,返回promise才能完成。 如果有任何 promise 被拒绝,返回的主 promise 就立即会被拒绝(抛弃任何其他 promise 的 结果)。如果完成的话,你会得到一个数组,其中包含传入的所有 promise 的完成值。对于 拒绝的情况,你只会得到第一个拒绝 promise 的拒绝理由值。
3、对Promise.race([ .. ])来说,只有第一个决议的promise(完成或拒绝)取胜,并且其 决议结果成为返回 promise 的决议。
var p1 = Promise.resolve( 42 ); var p2 = Promise.resolve( "Hello World" ); var p3 = Promise.reject( "Oops" ); Promise.race( [p1,p2,p3] ) .then( function(msg){ console.log( msg ); } ); Promise.all( [p1,p2,p3] ) .catch( function(err){ console.error( err ); } ); Promise.all( [p1,p2] ) .then( function(msgs){ console.log( msgs ); } ); // 42 // "Oops" // [42,"Hello World"] 复制代码
4、若向Promise.all([ .. ])传入空数组,它会立即完成,但Promise. race([ .. ]) 会挂住,且永远不会决议。
以上所述就是小编给大家介绍的《《你不知道的Javascript--中卷 学习总结》(异步、promise)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- ES6新特征总结与介绍——异步编程
- SpringBoot | :异步开发之异步调用
- 改进异步封装:处理带返回值的异步调用
- 异步发展流程 —— Generators + co 让异步更优雅
- 文件系统与异步操作——异步IO那些破事
- js异步从入门到放弃(四)- Generator 封装异步任务
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
进化式运营:从互联网菜鸟到绝顶高手
李少加 / 电子工业出版社 / 2016-11 / 59
互联网运营作为一个新兴的岗位,一方面它是企业的核心岗职,身负重任,另一方面,又由于其短暂的历史,缺乏成熟体系的工作方法论,而目前业界主流的运营方法却是从企业视角出发,存在极大的改进空间。 《进化式运营:从互联网菜鸟到绝顶高手》作者基于自身十年的互联网洞察、实践经验,并融合了信息论、心理学、经济学、管理学、甚至包括生态学、进化论等跨学科跨学业的知识,从无到有地构建了一套全新的互联网运营体系:基......一起来看看 《进化式运营:从互联网菜鸟到绝顶高手》 这本书的介绍吧!