本文整理匯總了TypeScript中cote.Responder.on方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Responder.on方法的具體用法?TypeScript Responder.on怎麽用?TypeScript Responder.on使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類cote.Responder
的用法示例。
在下文中一共展示了Responder.on方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: namespacesFront
namespacesFront() {
const responder = new cote.Responder({
name: 'Conversion Sockend Responder',
namespace: 'conversion'
});
const conversionRequester = new cote.Requester({
name: 'Conversion Requester',
key: 'conversion backend'
});
responder.on('convert', (req: any) => {
return conversionRequester.send(req); // proxy the request
});
}
示例2: responderCallback
responderCallback() {
const randomResponder = new cote.Responder({
name: 'Random Responder',
namespace: 'rnd',
key: 'a certain key',
respondsTo: ['randomRequest']
});
interface RandomRequest {
type: 'randomRequest';
payload: { val: number };
}
randomResponder.on('randomRequest', (req: RandomRequest, callback: (error: any, answer?: number) => void) => {
const answer = Math.floor(Math.random() * 10);
console.log('request', req.payload.val, 'answering with', answer);
callback(null, answer);
});
}
示例3: responder
responder() {
const randomResponder = new cote.Responder({
name: 'Random Responder',
namespace: 'rnd',
key: 'a certain key',
respondsTo: ['randomRequest']
});
interface RandomRequest {
type: 'randomRequest';
payload: { val: number };
}
randomResponder.on('randomRequest', (req: RandomRequest) => {
const answer = Math.floor(Math.random() * 10);
console.log('request', req.payload.val, 'answering with', answer);
return Promise.resolve(answer);
});
}
示例4: namespacesBack
namespacesBack() {
const responder = new cote.Responder({
name: 'Conversion Responder',
key: 'conversion backend'
});
const rates: { [key: string]: number } = {
usd_eur: 0.91,
eur_usd: 1.10
};
responder.on('convert', (req: cote.Action<{
amount: number,
from: string,
to: string
}>) => {
const { payload } = req;
return Promise.resolve(payload.amount * rates[`${payload.from}_${payload.to}`]);
});
}
示例5: eventEmitter
eventEmitter() {
const quitter = new cote.Requester({ name: 'Quitter' });
quitter.onAny(() => process.exit);
const indecisive = new cote.Responder({ name: 'Indecisive' });
const callback = <T>(x: T) => Promise.resolve(x);
indecisive.on('choice', callback);
indecisive.off('choice', callback);
const techno = new cote.Publisher({ name: 'Techno' });
techno.removeAllListeners();
const village = new cote.Subscriber({ name: 'Village' });
const doHelp = () => { };
village.many('wolf', 2, doHelp);
village.emit('wolf');
village.emit('wolf');
const emptyArray = village.listenersAny();
village.emit('wolf'); // no reaction
const eternity = new cote.Sockend(null as any, { name: 'Eternity' });
const handler = () => {
if (Math.random() === Number.MIN_VALUE) {
console.log('It happened.');
eternity.offAny(handler);
}
};
eternity.addListener('request', handler);
const monitor = new cote.Monitor({
name: 'Monitor',
port: 8025
});
monitor.setMaxListeners(1);
monitor.once('foobar', () => {
monitor.removeAllListeners();
monitor.once('foobar', () => {
console.log('Not a warning.');
});
});
}