npm-bluebird使用
注意
- 时刻注意
return
; - 使用
Promise.promisify
简化对test(val, function(err, result){})
的处理; - 尽量避免使用
deferred object
;
.spread
- 用于简化处理返回值是数组的情况;
- 用
es6
取代其处理返回数组的时候注意添加.all()
;
.catch()
- 允许传入错误类型(
error constructor
)来区别错误判断,包括:- TypeError,
- ReferenceError,
- EvalError,
- SyntaxError,
- RangeError,
- NetworkError,
- TimeoutError
- 也可以自己设置特别的错误类型,并且可以详细错误类型的信息;
- 可以传入一个返回布尔值的函数进行过滤;
- 传入一个对象简化判断;
.error
- 如果把错误分成
Operational errors
和programmer errors
,则可以用error
方法来处理前者;这些错误包括:
* failed to connect to server
* failed to resolve hostname
* invalid user input
* request timeout
* server returned a 500 response
* socket hang-up
* system is out of memory
.finally
fulfilled
状态后触发;并与之后的.then
方法同时被触发;fulfilled
状态触发后不会返回值到这个方法;同时其返回的方法也不会传递到下一个.then
方法;
Promise.try
- 传入函数,没有错误则其返回值为
fulfilled
状态,有错误则返回rejected
状态的错误;
Promise.method
- 处理机制与
Promise.try
类似,都传入函数;但其返回的是一个会返回promise
对象的方法;
Promise.resolve
- 将传入的数据转化为
promise
对象返回,除了原本是promise
对象且是rejected
状态的都会变成fulfilled
状态;
Promise.reject
- 将传入的数据转化为
promise
对象返回,状态都为rejected
;
Promise.bind/.bind
- 传入一个值,给后续的链式操作中绑定一个
this
为这个值;如果传入this
,则绑定的是.bind()
方法之前返回的值;
Collections
Promise.all
- 传入数组,当全部值为
fulfilled
状态时以数组形式传递返回值; - 当有一个值状态为
rejected
时将改值传递到错误处理;其他值不传递;
Promise.join
- 参数为一般参数加处理函数;处理函数相当于一个
.then
方法;
Promise.join(val1, val2, val3, function (val1, val2, val3) {}).then...
- 处理机制与
Promise.all
类似;
Promise.props
- 处理机制与
Promise.all
类似,接受对象处理;
Promise.any
- 接受数组,会返回第一个达到
fulfilled
状态的值;如果是空数组或都为rejected
状态,则全部返回错误处理; - 注意实际的运行时间是包括全部值的判断的;
Promise.some
- 第一参数为接受数组,第二参数为判断的个数; 设置个数必须,且不能大于数字个数,可以为0;
- 处理机制与
Promise.all
类似;返回最先到达设置个数的fulfilled
状态的值; - 如果参数中
fulfilled
状态的值达不到设定个数,返回rejected
状态的值到错误处理函数;
Promise.map
- 第一参数为接受数组,第二参数为判断函数;
Promise.reduce, Promise.filter, Promise.each
- 同上
.map
- 第一参数为判断函数;第二参数为设置并发数:
{concurrency: Infinity}
;设置并行个数能加快处理但不能保证返回顺序; - 注意传递过来的必须是数组;
.reduce, .filter, .each
- 同上
Promise.mapSeries/.mapSeries
- 与
Promise.map
类似;区别在于没有并发设置参数,如果其中一个为rejected
状态,则之后的值便不再处理;
Promise.race
- 接受数组,返回第一个达到
fulfilled
状态的值;
Resource management
Promise.using
- 接受多个参数,最后一个为处理前面参数的函数,在前面参数都为
fulfilled
状态时才会处理;
Promisification
Promise.promisify
Promise.promisifyAll
npm-bluebird使用的更多相关文章
- Visual Studio Code使用typings拓展自动补全功能
转自:http://blog.csdn.net/liyijun4114/article/details/51658087 参考来源: 官方介绍: https://code.visualstudio.c ...
- Windows Nodejs 安装教程
Windows Nodejs 安装教程 1: 访问官方地址 https://nodejs.org/en/download/ 2: 解压压缩包文件到指定目录 我直接把压缩包解压到C盘根目录下,并将文件夹 ...
- Cnblog页面美化小记
Cnblog页面美化小记 这两天我在网上翻找了许许多多的资料,打开了不计其数的博客,对着\(js\).\(html\).\(css\)等文件删删改改,在浏览器和\(vscode\)间辗转腾挪...总算 ...
- vs Code编辑器智能提示功能
一.Node.Js的Typings工具可以用于Visual Studio Code的代码补全 1.vscode 的默认只有es原声api带有自动补全的功能,现在V1.9的版本默认已经支持NodeJS的 ...
- Butterfly侧边栏引入一言
此教程涉及修改源码 背景 在修改每页显示7篇文章后,出现了这种情况. 这是完美主义(强迫症)的我所不能忍受的,有什么可以占据这里的呢?{% btn 'https://hitokoto.cn/',一言, ...
- VS Code nodejs智能补全typings
安装typings node.js自动补全使用npm全局安装typings npm install -g typings -安装语法插件以安装node.js自动补全为例,在项目根目录下使用bash或者 ...
- npm 模块常用命令
mocha mocha --compilers js:babel/register : 在babel模式下测试,默认查找test文件夹,注意此时全局不要安装babel; ./node_modules/ ...
- Appium 命令行模式下遇到的问题总结及解决方案 npm ERR! tar.unpack unzip(或者untar) error
安装了GUI Appium后,卸载删除问题后,使用命令行模式安装. 一. 遇到问题: nalideMacBook-Pro:~ nali$ npm install -g appium npm ERR! ...
- bluebird的安装配置
安装 下载bluebird 3.5.0(开发) 意味着在开发中使用的未分类源文件.警告和长堆栈跟踪被启用,这会影响性能. <script src="//cdn.jsdelivr.net ...
- promise 进阶 —— async / await 结合 bluebird
一.背景 1.Node.js 异步控制 在之前写的 callback vs async.js vs promise vs async / await 里,我介绍了 ES6 的 promise 和 ES ...
随机推荐
- POJ 2342 Anniversary party(树形dp)
Anniversary party Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7230 Accepted: 4162 ...
- Linux/Mac/Shell常用命令
常用命令 · ls 查看当前目录下的文件 · cd 进入某目录 · cd - 跳转回前一目录 · cd ~ 进入当前用户个人目录 · pwd 输出当前所在路径 · mkdir 新建文件夹 · touc ...
- 看完《Thinking in Java》后,我觉得自己就是一个不懂编程的小孩子,如何快速摆脱这种自卑感
我虽然不懂java也不懂程序员,但我理解这种心情.当看到自己还算自信的专业领域中一部超越自己水平很多的作品或比自己优秀太多的人,难免会感到震惊,继而进行自我否定.就像我曾经非常喜欢写作,在杂志和校报上 ...
- php htmlentities函数的问题
看到在细说php第二版教程中的函数htmlentities 例子,实际实验没有效果 $str = "一个 'quote' 是<b>bold</b>";ech ...
- LoadRunner 函数之lr_xml_get_values
简单实例如 char *xml_input = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>&q ...
- 转:C#中TransactionScope的使用方法和原理
在.net 1.1的时代,还没有TransactionScope类,因此很多关于事务的处理,都交给了SqlTransaction和SqlConnection,每个Transaction是基于每个Con ...
- 为什么为 const 变量重新赋值不是个静态错误
const 和 let 的唯一区别就是用 const 声明的变量不能被重新赋值(只读变量),比如像下面这样就会报错: const foo = 1 foo = 2 // TypeError: Assig ...
- log4j的使用详细解析
1 Log4j配置说明 1.1 配置文件Log4j可以通过java程序动态设置,该方式明显缺点是:如果需要修改日志输出级别等信息,则必须修改java文件,然后重新编译,很是麻烦: log4j也可以通过 ...
- UI第十四节——UIAlertController
- (void)viewDidLoad { [super viewDidLoad]; UIButton *alertBtn = [UIButton buttonWithType:U ...
- JavaScript类型判断instanceof与typeof对比
经常有人会在JavaScript里写如下的方法: function checkType() { var s1 = 123; var s2 = "OK"; if (s1 instan ...