本文整理匯總了TypeScript中@reactivex/rxjs.Observable.bufferTime方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Observable.bufferTime方法的具體用法?TypeScript Observable.bufferTime怎麽用?TypeScript Observable.bufferTime使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類@reactivex/rxjs.Observable
的用法示例。
在下文中一共展示了Observable.bufferTime方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: to
to(topic: string, iO: Observable<any>): Subscription<any> {
let client = this.getClient();
let producer = new kafka.Producer(client);
let buffer = [];
let handleErr = err => {
if (err) { throw err; }
};
producer.on('ready', () => {
if (!buffer.length) { return; }
producer.send([{
topic: topic,
messages: buffer
}], handleErr);
});
return iO
// Things run faster overall with a little buffering
.bufferTime(50)
.subscribe(
msg => {
if (!msg.length) { return; }
for (let i = msg.length - 1; i >= 0; i--) {
msg[i] = typeof msg[i] === 'string' ? msg[i] : JSON.stringify(msg[i]);
}
if (!producer.ready) {
buffer = buffer.concat(msg);
return;
}
producer.send([{
topic: topic,
messages: msg
}], handleErr);
},
handleErr,
() => {
producer.send([{
topic: topic,
messages: ['__done']
}]);
}
);
}