schangxiang@126.com
2025-09-19 0821aa23eabe557c0d9ef5dbe6989c68be35d1fe
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
[![Travis CI](https://travis-ci.org/digitaldesignlabs/es6-promisify.svg)](https://travis-ci.org/digitaldesignlabs/es6-promisify)
 
# es6-promisify
 
Converts callback-based functions to Promise-based functions.
 
## Install
 
Install with [npm](https://npmjs.org/package/es6-promisify)
 
```bash
npm install --save es6-promisify
```
 
## Example
 
```js
"use strict";
 
// Declare variables
const promisify = require("es6-promisify");
const fs = require("fs");
 
// Convert the stat function
const stat = promisify(fs.stat);
 
// Now usable as a promise!
stat("example.txt").then(function (stats) {
    console.log("Got stats", stats);
}).catch(function (err) {
    console.error("Yikes!", err);
});
```
 
## Promisify methods
```js
"use strict";
 
// Declare variables
const promisify = require("es6-promisify");
const redis = require("redis").createClient(6379, "localhost");
 
// Create a promise-based version of send_command
const client = promisify(redis.send_command, redis);
 
// Send commands to redis and get a promise back
client("ping").then(function (pong) {
    console.log("Got", pong);
}).catch(function (err) {
    console.error("Unexpected error", err);
}).then(function () {
    redis.quit();
});
```
 
## Handle callback multiple arguments
```js
"use strict";
 
// Declare functions
function test(cb) {
    return cb(undefined, 1, 2, 3);
}
 
// Declare variables
const promisify = require("es6-promisify");
 
// Create promise-based version of test
const single = promisify(test);
const multi = promisify(test, {multiArgs: true});
 
// Discards additional arguments
single().then(function (result) {
    console.log(result); // 1
});
 
// Returns all arguments as an array
multi().then(function (result) {
    console.log(result); // [1, 2, 3]
});
```
 
### Tests
Test with nodeunit
```bash
$ npm test
```
 
Published under the [MIT License](http://opensource.org/licenses/MIT).