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


TypeScript delay.default函數代碼示例

本文整理匯總了TypeScript中xstream/extra/delay.default函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript default函數的具體用法?TypeScript default怎麽用?TypeScript default使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了default函數的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: Child

    function Child(sources: {state: StateSource<ItemState>}) {
      const defaultReducer$ = xs.of((prev: ItemState) => {
        if (typeof prev.val === 'number') {
          return prev;
        } else {
          return {id: prev.id, val: 10};
        }
      });

      const deleteReducer$ = xs
        .of((prev: ItemState) => (prev.id === 'c' ? void 0 : prev))
        .compose(delay(50));

      return {
        state: xs.merge(defaultReducer$, deleteReducer$),
      };
    }
開發者ID:,項目名稱:,代碼行數:17,代碼來源:

示例2: app

 function app(sources: {DOM: DOMSource}) {
   return {
     DOM: concat(
       xs.of(h2('.blesh', 'Blesh')),
       xs.of(h3('.blish', 'Blish')).compose(delay(150)),
       xs.of(h4('.blosh', 'Blosh')).compose(delay(150)),
     ),
   };
 }
開發者ID:joeldentici,項目名稱:cyclejs,代碼行數:9,代碼來源:events.ts

示例3: Main

    function Main(sources: {state: StateSource<any>}) {
      sources.state.stream.addListener({
        next(x) {
          assert.deepEqual(x.list, expected.shift());
        },
        error(e) {
          done(e.message);
        },
        complete() {
          done('complete should not be called');
        },
      });

      const childSinks = isolate(List, 'list')(sources);
      const childReducer$ = childSinks.state;

      const initReducer$ = xs.of(function initReducer(prevState: any): any {
        return {list: [{val: 3}]};
      });

      const addReducer$ = xs
        .of(function addSecond(prev: any) {
          return {list: prev.list.concat({val: null})};
        })
        .compose(delay(100));

      const parentReducer$ = xs.merge(initReducer$, addReducer$);
      const reducer$ = xs.merge(parentReducer$, childReducer$) as Stream<
        Reducer<any>
      >;

      return {
        state: reducer$,
      };
    }
開發者ID:,項目名稱:,代碼行數:35,代碼來源:

示例4:

 const Dataflow = ({ circular$}: Sources & Circular): Sinks & Circular => {
   return {
     circular$: circular$.map(x => x * 2)
       .startWith(1)
       .compose(delay(10)),
     target$: circular$.map(x => x * 10)
   }
 }
開發者ID:whitecolor,項目名稱:cycle-circular,代碼行數:8,代碼來源:xstream.ts

示例5: app

  it('should not simulate bubbling for non-bubbling events', done => {
    function app(_sources: {DOM: DOMSource}) {
      return {
        DOM: xs.of(
          div('.parent', [form('.form', [input('.field', {type: 'text'})])])
        ),
      };
    }

    const {sinks, sources, run} = setup(app, {
      DOM: makeDOMDriver(createRenderTarget()),
    });

    sources.DOM.select('.parent')
      .events('reset')
      .addListener({
        next: (ev: Event) => {
          done(new Error('Reset event should not bubble to parent'));
        },
      });

    sources.DOM.select('.form')
      .events('reset')
      .compose(delay(200))
      .addListener({
        next: (ev: Event) => {
          assert.strictEqual(ev.type, 'reset');
          const target = ev.target as HTMLElement;
          assert.strictEqual(target.tagName, 'FORM');
          assert.strictEqual(target.className, 'form');
          done();
        },
      });

    sources.DOM.select(':root')
      .element()
      .drop(1)
      .take(1)
      .addListener({
        next: (root: Element) => {
          const _form = root.querySelector('.form') as HTMLFormElement;
          setTimeout(() => _form.reset());
        },
      });
    run();
  });
開發者ID:ntilwalli,項目名稱:cyclejs,代碼行數:46,代碼來源:events.ts

示例6: main

 function main(sources: {DOM: MainDOMSource}) {
   const remove$ = componentRemove$.compose(delay(50)).fold((acc) => acc + 1, 0);
   const first = isolate(Component, 'first')(sources);
   const second = isolate(Component, 'second')(sources);
   const vdom$ = xs.combine(first.DOM, second.DOM, remove$)
     .map(([vdom1, vdom2, r]) => {
       if (r === 0) {
         return div([vdom1, vdom2]);
       } else if (r === 1) {
         return div([vdom2]);
       } else if (r === 2) {
         return div([]);
       } else {
         done('This case must not happen.');
       }
     });
   return { DOM: vdom$ };
 }
開發者ID:whitecolor,項目名稱:cyclejs,代碼行數:18,代碼來源:isolation.ts

示例7: app

 function app(sources: {DOM: MainDOMSource}) {
   const vtree1$ = xs.of(span('.tab1', 'Hi'));
   const vtree2$ = xs.of(span('.tab2', 'Hello'));
   const first$ = sources.DOM.isolateSink(vtree1$, '1');
   const second$ = sources.DOM.isolateSink(vtree2$, '2');
   const switched$ = concat(
     xs.of(1).compose(delay(50)),
     xs.of(2).compose(delay(50)),
     xs.of(1).compose(delay(50)),
     xs.of(2).compose(delay(50)),
     xs.of(1).compose(delay(50)),
     xs.of(2).compose(delay(50)),
   ).map(i => i === 1 ? first$ : second$).flatten();
   return {
     DOM: switched$,
   };
 }
開發者ID:whitecolor,項目名稱:cyclejs,代碼行數:17,代碼來源:isolation.ts

示例8: driver

 function driver(sink: Stream<string>) {
   return sink.map(x => x.charCodeAt(0)).compose(delay(1));
 }
開發者ID:joeldentici,項目名稱:cyclejs,代碼行數:3,代碼來源:index.ts


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