本文整理匯總了TypeScript中rxjs.bindNodeCallback函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript bindNodeCallback函數的具體用法?TypeScript bindNodeCallback怎麽用?TypeScript bindNodeCallback使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了bindNodeCallback函數的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: it
it('should cache value for next subscription and not call callbackFunc again', () => {
let calls = 0;
function callback(datum: number, cb: (err: any, n: number) => void) {
calls++;
cb(null, datum);
}
const boundCallback = bindNodeCallback(callback, rxTestScheduler);
const results1: Array<number | string> = [];
const results2: Array<number | string> = [];
const source = boundCallback(42);
source.subscribe(x => {
results1.push(x);
}, null, () => {
results1.push('done');
});
source.subscribe(x => {
results2.push(x);
}, null, () => {
results2.push('done');
});
rxTestScheduler.flush();
expect(calls).to.equal(1);
expect(results1).to.deep.equal([42, 'done']);
expect(results2).to.deep.equal([42, 'done']);
});
示例2: mergeMap
const compileScssFile = mergeMap((file: WorkFile) => {
const compileSass$: any = bindNodeCallback(renderSass);
return compileSass$({file: file.src}).pipe(
mergeMap((res: Result) => processCss(res.css)),
mergeMap((result: any) => createCssFile(file.distCss, result.css)),
tap(() => logSuccess(file))
);
});
示例3: function
constructorZone.run(() => {
func = function(arg: any, callback: (error: any, result: any) => any) {
expect(Zone.current.name).toEqual(constructorZone.name);
callback(null, arg);
};
boundFunc = bindNodeCallback(func);
observable = boundFunc('test');
});