Promise + Generator for async pipe.
- provide
pipe
for JavaScript butchainable
; - provide
goto
for JavaScript butcallback
; - provide
Asynchronous Programming
without Generators and Promise; - pipe functions will be run after all sync statements be done;
- allow multiple parameters to next pipe function;
This module export as es2015-module, you need use es6 module to import es6-async-pipe
, you can npm install --save-dev webpack babel-core babel-loader babel-preset-es2015 babel-preset-stage-0 babel-runtime
.
{
...
"devDependencies": {
"babel-core": "^6.7.4",
"babel-loader": "^6.2.4",
"babel-preset-es2015": "^6.6.0",
"babel-preset-stage-0": "^6.5.0",
"babel-runtime": "^6.6.1",
"webpack": "^1.12.14",
...
}
...
}
npm install es6-async-pipe --save-dev
import pipe from 'es6-async-pipe';
let pipeA = pipe(...fns);
let pipeB = pipe(data, ...fns); // create a pipe with initial data for following functions call
function async(...args) {
const timeout = window.setTimeout(function() {
window.clearTimeout(timeout);
args[0].a++;
this.next(...args);
}.bind(this), 1000 + Math.random() * 2000);
}
function sync(...args) {
args[0].a++;
this.next(...args);
}
// just run async functions
pipe({ a: 0 }, async, async, async);
// just run sync functions
pipe({ a: 0 }, sync, sync, sync);
// run async and sync functions
pipe({ a: 0 }, async, sync, async).done((...args) => {
console.log(args);
});
function done(...args) {
const timeout = window.setTimeout(function() {
window.clearTimeout(timeout);
this.done();
}.bind(this), 1000 + Math.random() * 2000);
}
function cancel(...args) {
const timeout = window.setTimeout(function() {
window.clearTimeout(timeout);
this.cancel('something happened!');
}.bind(this), 1000 + Math.random() * 2000);
}
// done pipe but not wait pipe take all functions
pipe({ a: 0 }, async, done, async/* this function won't be executed */);
// cancel pipe and throw reason
pipe({ a: 0 }, async, cancel, async/* this function won't be executed */);
function named(...args) {
this.define('async');
const timeout = window.setTimeout(function() {
window.clearTimeout(timeout);
args[0].a++;
this.next(...args);
}.bind(this), 1000 + Math.random() * 2000);
}
function goto(...args) {
const timeout = window.setTimeout(function() {
window.clearTimeout(timeout);
if(args[0].a < 5){
this.goto('async', ...args);
} else {
this.next(...args);
}
}.bind(this), 1000 + Math.random() * 2000);
}
// goto a named function
pipe({ a: 0 }, named/* this function will be call 5 times */, goto, async);
pipe({ a: 0 }, async, function(){
// no this.done(), this.cancel() and this.next()
// do another things not belongs to this pipe is allowed
}, async);
let fns = [];
fns.push(fn);
pipe.apply(null, fns);
Do something when pipe is done:
- if all pipe functions have been done;
- some pipe function take this.done();
pipe(fn, fn, fn, ...).done(fn);
If some exceptions, then catch them.
pipe(fn, fn, fn, ...).catch(fn);
Before pipe start.
pipe(fn, fn, fn, ...).before(fn);
After pipe end.
pipe(fn, fn, fn, ...).after(fn);
Before enter each pipe function.
pipe(fn, fn, fn, ...).beforeEach(fn);
After quit each pipe function.
pipe(fn, fn, fn, ...).afterEach(fn);
Enable the debug and return logs.
pipe(fn, fn, fn, ...).debug(function(logs){
console.log(logs.join('\n'));
});
Console output:
Enter pipe function
├ Time offset(ms): 1
└ Value snapshot: [{"a":0}]
Exit pipe function
├ Time offset(ms): 1122
└ Value snapshot: [{"a":1}]
Enter pipe function
├ Time offset(ms): 1122
└ Value snapshot: [{"a":2}]
Exit pipe function
├ Time offset(ms): 3701
└ Value snapshot: [{"a":3}]
Enter pipe function
├ Time offset(ms): 3702
└ Value snapshot: [{"a":4}]
Exit pipe function
├ Time offset(ms): 5330
└ Value snapshot: [{"a":5}]
Async pipe completed
├ Time offset(ms): 5331
└ Value snapshot: [{"a":5}]
pipe.add(fns)
,pipe.remove(fn)
andpipe.insert(fn, position)
?pipe.sleep()
to resolve competition of othersetTimeout
functions?- multiple pipe runtime support to resolve competition of other pipe?