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


TypeScript Stream.map方法代碼示例

本文整理匯總了TypeScript中xstream.Stream.map方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Stream.map方法的具體用法?TypeScript Stream.map怎麽用?TypeScript Stream.map使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在xstream.Stream的用法示例。


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

示例1: Button

function Button(sources: Sources): Sinks {
	let props$: Stream<ButtonProps> = sources.props$;
	const click$ = sources.DOM.select('.button').events('click')
	const delta$ = props$.map(
		(props) => click$.map((ev) => props.amount)
	).flatten();
	const vdom$ = props$.map(props => button('.button', [props.text]));

	return {
		DOM: vdom$,
		delta$: delta$
	}
}
開發者ID:mxstbr,項目名稱:cyclejs-counter,代碼行數:13,代碼來源:Button.ts

示例2: __commits

 private __commits() {
   const response$$: Stream<Stream<Response>> = this.http.select('commits');
   return response$$
     .map(response$ => response$.replaceError(() => xs.of({ status: 500, body: [] } as Response)))
     .flatten()
     .map(response => response.body as Commit[]);
 }
開發者ID:cyclejs-community,項目名稱:typescript-starter-cycle,代碼行數:7,代碼來源:github.ts

示例3: totalIsolateSink

export function totalIsolateSink(
  sink: Stream<VNode | null | undefined>,
  fullScope: string,
): Stream<VNode | null | undefined> {
  return sink.map(node => {
    if (!node) {
      return node;
    }
    // Ignore if already had up-to-date full scope in vnode.data.isolate
    if (node.data && (node.data as any).isolate) {
      const isolateData = (node.data as any).isolate as string;
      const prevFullScopeNum = isolateData.replace(/(cycle|\-)/g, '');
      const fullScopeNum = fullScope.replace(/(cycle|\-)/g, '');

      if (
        isNaN(parseInt(prevFullScopeNum)) ||
        isNaN(parseInt(fullScopeNum)) ||
        prevFullScopeNum > fullScopeNum
      ) {
        // > is lexicographic string comparison
        return node;
      }
    }

    // Insert up-to-date full scope in vnode.data.isolate, and also a key if needed
    node.data = node.data || {};
    (node.data as any).isolate = fullScope;
    if (typeof node.key === 'undefined') {
      node.key = SCOPE_PREFIX + fullScope;
    }
    return node;
  });
}
開發者ID:joeldentici,項目名稱:cyclejs,代碼行數:33,代碼來源:isolate.ts

示例4: driver

 function driver(sink: Stream<number>): Stream<string> {
   return sink.map(x => 'a' + 10).debug(x => {
     assert.strictEqual(x, 'a10');
     assert.strictEqual(mutable, 'correct');
     spy();
   });
 }
開發者ID:joeldentici,項目名稱:cyclejs,代碼行數:7,代碼來源:index.ts

示例5: intent

function intent(HTTPSource: HTTPSource): Intent {
  const url = 'http://swapi.co/api/people/'

  const usersReq$: Stream<RequestOptions> = xs.of({ url, category: 'users' })

  const users$: Stream<User[]> = HTTPSource
    .select('users')
    .flatten()
    .map((res: Response<UsersResBody>) => res.body.results)

  const homeworldsReq$: Stream<RequestOptions> = users$.map((users: User[]): Stream<RequestOptions> => {
    return xs.fromArray(users.map((user: User): RequestOptions => {
      return { url: user.homeworld, category: 'homeworld' }
    }))
  }).flatten()

  const homeworlds$ = HTTPSource
    .select('homeworld')
    .compose(flattenConcurrently)
    .map((res: Response<Planet>) => res.body)
    .fold((acc: Planet[], homeworld: Planet) => {
      acc = acc.concat(homeworld)
      return acc
    }, [])

  return { users$, homeworlds$, usersReq$, homeworldsReq$ }
}
開發者ID:jaketrent,項目名稱:swapi-cycle-ts,代碼行數:27,代碼來源:index.ts

示例6: httpDriver

 function httpDriver(request$: Stream<RequestInput>, name: string): HTTPSource {
   const response$$ = request$
     .map(requestInputToResponse$);
   const httpSource = new MainHTTPSource(response$$, name, []);
   response$$.addListener({next: () => {}, error: () => {}, complete: () => {}});
   return httpSource;
 }
開發者ID:whitecolor,項目名稱:cyclejs,代碼行數:7,代碼來源:http-driver.ts

示例7: __commitBySha

 private __commitBySha(sha: string) {
   const response$$: Stream<Stream<Response>> = this.http.select(`commit-by-sha-${sha}`);
   return response$$
     .map(response$ => response$.replaceError(() => xs.of({ status: 500, body: {} } as Response)))
     .flatten()
     .map(response => response.body as Commit);
 }
開發者ID:cyclejs-community,項目名稱:typescript-starter-cycle,代碼行數:7,代碼來源:github.ts

示例8: htmlDriver

 function htmlDriver(vnode$: Stream<VNode>, name: string): HTMLSource {
   const html$ = vnode$.map(toHTML);
   html$.addListener({
     next: effect || noop,
     error: noop,
     complete: noop,
   });
   return new HTMLSource(html$, name);
 };
開發者ID:whitecolor,項目名稱:cyclejs,代碼行數:9,代碼來源:makeHTMLDriver.ts

示例9: view

function view(state$: Stream<ViewState[]>): Stream<VNode> {
  return state$.map(state =>
    ul(
      state.map((model: ViewState) =>
        li(`${model.user.name} - ${model.homeworld ? model.homeworld.name : 'UNKNOWN'}`)
      )
    )
  )
}
開發者ID:jaketrent,項目名稱:swapi-cycle-ts,代碼行數:9,代碼來源:index.ts

示例10: helixPiDriver

function helixPiDriver(sink$: Stream<Input>) {
  const worker = work(require("./worker"));

  const driver = makeWebWorkerDriver(worker);

  const stringifiedSink$ = sink$.map(event => JSON.stringify(event));

  return driver(stringifiedSink$).map(source => JSON.parse(source));
}
開發者ID:helix-pi,項目名稱:helix-pi,代碼行數:9,代碼來源:editor.ts


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