p-tap
Tap into a promise chain without affecting its value or state
Install
$ npm install --save p-tap
Usage
const pTap = require('p-tap');
Promise.resolve('unicorn')
.then(pTap(console.log)) // logs `unicorn`
.then(value => {
// `value` is still `unicorn`
});
const pTap = require('p-tap');
getUser()
.then(pTap(user => recordStatsAsync(user))) // stats are saved about `user` async before the chain continues
.then(user => {
// `user` is the user from getUser(), not recordStatsAsync()
});
const pTap = require('p-tap');
Promise.resolve(() => doSomething())
.catch(pTap.catch(console.error)) // prints any errors
.then(handleSuccess)
.catch(handleError);
API
pTap(input)
Use this in a .then()
method.
Returns a thunk that returns a Promise
.
pTap.catch(input)
Use this in a .catch()
method.
Returns a thunk that returns a Promise
.
input
Type: Function
Any return value or exception is ignored.
If input
returns a Promise
, it will be awaited before passing through the original value.
Related
- p-log - Log the value/error of a promise
- p-if - Conditional promise chains
- p-catch-if - Conditional promise catch handler
- More…
License
MIT © Sindre Sorhus