注意

  • 时刻注意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 errorsprogrammer 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使用的更多相关文章

  1. Visual Studio Code使用typings拓展自动补全功能

    转自:http://blog.csdn.net/liyijun4114/article/details/51658087 参考来源: 官方介绍: https://code.visualstudio.c ...

  2. Windows Nodejs 安装教程

    Windows Nodejs 安装教程 1: 访问官方地址 https://nodejs.org/en/download/ 2: 解压压缩包文件到指定目录 我直接把压缩包解压到C盘根目录下,并将文件夹 ...

  3. Cnblog页面美化小记

    Cnblog页面美化小记 这两天我在网上翻找了许许多多的资料,打开了不计其数的博客,对着\(js\).\(html\).\(css\)等文件删删改改,在浏览器和\(vscode\)间辗转腾挪...总算 ...

  4. vs Code编辑器智能提示功能

    一.Node.Js的Typings工具可以用于Visual Studio Code的代码补全 1.vscode 的默认只有es原声api带有自动补全的功能,现在V1.9的版本默认已经支持NodeJS的 ...

  5. Butterfly侧边栏引入一言

    此教程涉及修改源码 背景 在修改每页显示7篇文章后,出现了这种情况. 这是完美主义(强迫症)的我所不能忍受的,有什么可以占据这里的呢?{% btn 'https://hitokoto.cn/',一言, ...

  6. VS Code nodejs智能补全typings

    安装typings node.js自动补全使用npm全局安装typings npm install -g typings -安装语法插件以安装node.js自动补全为例,在项目根目录下使用bash或者 ...

  7. npm 模块常用命令

    mocha mocha --compilers js:babel/register : 在babel模式下测试,默认查找test文件夹,注意此时全局不要安装babel; ./node_modules/ ...

  8. Appium 命令行模式下遇到的问题总结及解决方案 npm ERR! tar.unpack unzip(或者untar) error

    安装了GUI Appium后,卸载删除问题后,使用命令行模式安装. 一. 遇到问题: nalideMacBook-Pro:~ nali$ npm install -g appium npm ERR! ...

  9. bluebird的安装配置

    安装 下载bluebird 3.5.0(开发) 意味着在开发中使用的未分类源文件.警告和长堆栈跟踪被启用,这会影响性能. <script src="//cdn.jsdelivr.net ...

  10. promise 进阶 —— async / await 结合 bluebird

    一.背景 1.Node.js 异步控制 在之前写的 callback vs async.js vs promise vs async / await 里,我介绍了 ES6 的 promise 和 ES ...

随机推荐

  1. POJ 2342 Anniversary party(树形dp)

    Anniversary party Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7230   Accepted: 4162 ...

  2. Linux/Mac/Shell常用命令

    常用命令 · ls 查看当前目录下的文件 · cd 进入某目录 · cd - 跳转回前一目录 · cd ~ 进入当前用户个人目录 · pwd 输出当前所在路径 · mkdir 新建文件夹 · touc ...

  3. 看完《Thinking in Java》后,我觉得自己就是一个不懂编程的小孩子,如何快速摆脱这种自卑感

    我虽然不懂java也不懂程序员,但我理解这种心情.当看到自己还算自信的专业领域中一部超越自己水平很多的作品或比自己优秀太多的人,难免会感到震惊,继而进行自我否定.就像我曾经非常喜欢写作,在杂志和校报上 ...

  4. php htmlentities函数的问题

    看到在细说php第二版教程中的函数htmlentities 例子,实际实验没有效果 $str = "一个 'quote' 是<b>bold</b>";ech ...

  5. LoadRunner 函数之lr_xml_get_values

    简单实例如 char *xml_input = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>&q ...

  6. 转:C#中TransactionScope的使用方法和原理

    在.net 1.1的时代,还没有TransactionScope类,因此很多关于事务的处理,都交给了SqlTransaction和SqlConnection,每个Transaction是基于每个Con ...

  7. 为什么为 const 变量重新赋值不是个静态错误

    const 和 let 的唯一区别就是用 const 声明的变量不能被重新赋值(只读变量),比如像下面这样就会报错: const foo = 1 foo = 2 // TypeError: Assig ...

  8. log4j的使用详细解析

    1 Log4j配置说明 1.1 配置文件Log4j可以通过java程序动态设置,该方式明显缺点是:如果需要修改日志输出级别等信息,则必须修改java文件,然后重新编译,很是麻烦: log4j也可以通过 ...

  9. UI第十四节——UIAlertController

    - (void)viewDidLoad {    [super viewDidLoad];        UIButton *alertBtn = [UIButton buttonWithType:U ...

  10. JavaScript类型判断instanceof与typeof对比

    经常有人会在JavaScript里写如下的方法: function checkType() { var s1 = 123; var s2 = "OK"; if (s1 instan ...