當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Responder.on方法代碼示例

本文整理匯總了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
        });
    }
開發者ID:AlexGalays,項目名稱:DefinitelyTyped,代碼行數:15,代碼來源:cote-tests.ts

示例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);
        });
    }
開發者ID:AlexGalays,項目名稱:DefinitelyTyped,代碼行數:19,代碼來源:cote-tests.ts

示例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);
        });
    }
開發者ID:AlexGalays,項目名稱:DefinitelyTyped,代碼行數:19,代碼來源:cote-tests.ts

示例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}`]);
        });
    }
開發者ID:isman-usoh,項目名稱:DefinitelyTyped,代碼行數:20,代碼來源:cote-tests.ts

示例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.');
            });
        });
    }
開發者ID:AlexGalays,項目名稱:DefinitelyTyped,代碼行數:41,代碼來源:cote-tests.ts


注:本文中的cote.Responder.on方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。