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


TypeScript rxjs.combineLatest函數代碼示例

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


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

示例1: bindTranscript

 bindTranscript(records: any[]): Observable<LiftedData> {
   const crosslistedRecords = combineLatest(
     records.filter(record => record.quality).map(record =>
       this.institution
         .course(record.course)
         .data()
         .pipe(
           map(data => [record.course, ...(data.crosslists || [])] as string[])
         )
     )
   );
   return combineLatest(
     this.data().pipe(
       map(function lift(program: ProgramData): LiftedData {
         return {
           requirements: program.requirements
             ? program.requirements.map(requirement => lift(requirement))
             : null,
           program,
           progress: {} as ProgressData
         } as LiftedData;
       })
     ),
     records.length == 0 ? of([]) : crosslistedRecords
   ).pipe(
     map(([lifted, crosslistedRecords]) =>
       resolve(lifted, crosslistedRecords.slice())
     )
   );
 }
開發者ID:kevmo314,項目名稱:canigraduate.uchicago.edu,代碼行數:30,代碼來源:program.ts

示例2: type

 type('should support arrays of observables', () => {
   /* tslint:disable:no-unused-variable */
   let a: Observable<number>[];
   let o1: Observable<number[]> = combineLatest(a);
   let o2: Observable<number[]> = combineLatest(...a);
   let o3: Observable<number> = combineLatest(a, (...x: any[]) => x.length);
   /* tslint:enable:no-unused-variable */
 });
開發者ID:DallanQ,項目名稱:rxjs,代碼行數:8,代碼來源:combineLatest-spec.ts

示例3: test

  test('returns data and admin client observables as a part of the contract', async () => {
    const mockAdminClusterClientInstance = { close: jest.fn() };
    const mockDataClusterClientInstance = { close: jest.fn() };
    MockClusterClient.mockImplementationOnce(
      () => mockAdminClusterClientInstance
    ).mockImplementationOnce(() => mockDataClusterClientInstance);

    const setupContract = await elasticsearchService.setup();

    const [esConfig, adminClient, dataClient] = await combineLatest(
      setupContract.legacy.config$,
      setupContract.adminClient$,
      setupContract.dataClient$
    )
      .pipe(first())
      .toPromise();

    expect(adminClient).toBe(mockAdminClusterClientInstance);
    expect(dataClient).toBe(mockDataClusterClientInstance);

    expect(MockClusterClient).toHaveBeenCalledTimes(2);
    expect(MockClusterClient).toHaveBeenNthCalledWith(
      1,
      esConfig,
      expect.objectContaining({ context: ['elasticsearch', 'admin'] })
    );
    expect(MockClusterClient).toHaveBeenNthCalledWith(
      2,
      esConfig,
      expect.objectContaining({ context: ['elasticsearch', 'data'] })
    );

    expect(mockAdminClusterClientInstance.close).not.toHaveBeenCalled();
    expect(mockDataClusterClientInstance.close).not.toHaveBeenCalled();
  });
開發者ID:elastic,項目名稱:kibana,代碼行數:35,代碼來源:elasticsearch_service.test.ts

示例4: applyInternal

 protected applyInternal(node: Element, directive: IDirective<string>, state: INodeState) {
     const observable = directive.evaluate(this.dataFlow) as Observable<string> | Observable<string>[];
     let subscription;
     if (Array.isArray(observable)) {
         subscription = combineLatest(observable).subscribe(values => {
             const zipped = directive.parameters.map((text, i) => {
                 let value = values[i];
                 if ((value === null) || (value === undefined)) {
                     value = "";
                 } else if (Array.isArray(value)) {
                     value = value.join(", ");
                 }
                 return text + value;
             });
             node.nodeValue = zipped.join("");
         });
     } else {
         subscription = observable.subscribe(value => {
             if ((value === null) || (value === undefined)) {
                 value = "";
             } else if (Array.isArray(value)) {
                 value = value.join(", ");
             }
             node.textContent = value;
         });
     }
     directive.cleanup.add(subscription);
 }
開發者ID:milutinovici,項目名稱:proactive,代碼行數:28,代碼來源:text.ts

示例5: switchMap

  return switchMap(obs => {
    return combineLatest(
               ...obs.map(o => o.pipe(take(1), startWith(INITIAL_VALUE as INTERIM_VALUES))))
        .pipe(
            scan(
                (acc: INTERIM_VALUES, list: INTERIM_VALUES[]) => {
                  let isPending = false;
                  return list.reduce((innerAcc, val, i: number) => {
                    if (innerAcc !== INITIAL_VALUE) return innerAcc;

                    // Toggle pending flag if any values haven't been set yet
                    if (val === INITIAL_VALUE) isPending = true;

                    // Any other return values are only valid if we haven't yet hit a pending call.
                    // This guarantees that in the case of a guard at the bottom of the tree that
                    // returns a redirect, we will wait for the higher priority guard at the top to
                    // finish before performing the redirect.
                    if (!isPending) {
                      // Early return when we hit a `false` value as that should always cancel
                      // navigation
                      if (val === false) return val;

                      if (i === list.length - 1 || val instanceof UrlTree) {
                        return val;
                      }
                    }

                    return innerAcc;
                  }, acc);
                },
                INITIAL_VALUE),
            filter(item => item !== INITIAL_VALUE), take(1)) as Observable<boolean|UrlTree>;
  });
開發者ID:KaneFreeman,項目名稱:angular,代碼行數:33,代碼來源:prioritized_guard_value.ts

示例6: combineLatest1

  combineLatest1() {
    // timerOne emits first value at 1s, then once every 4s
    const timerOne = timer(1000, 4000);
    // timerTwo emits first value at 2s, then once every 4s
    const timerTwo = timer(2000, 4000);
    // timerThree emits first value at 3s, then once every 4s
    const timerThree = timer(3000, 4000);

    // when one timer emits, emit the latest values from each timer as an array
    const combined = combineLatest(timerOne, timerTwo, timerThree);

    const subscribe = combined.subscribe(
      ([timerValOne, timerValTwo, timerValThree]) => {
        /*
      	Example:
        timerOne first tick: 'Timer One Latest: 1, Timer Two Latest:0, Timer Three Latest: 0
        timerTwo first tick: 'Timer One Latest: 1, Timer Two Latest:1, Timer Three Latest: 0
        timerThree first tick: 'Timer One Latest: 1, Timer Two Latest:1, Timer Three Latest: 1
      */
        console.log(
          `Timer One Latest: ${timerValOne},
         Timer Two Latest: ${timerValTwo},
         Timer Three Latest: ${timerValThree}`
        );
      }
    );
  }
開發者ID:zwvista,項目名稱:SampleMisc,代碼行數:27,代碼來源:combining.service.ts

示例7: of

 observable1 = constructorZone1.run(() => {
   const source = of(1, 2, 3);
   const input = of(4, 5, 6);
   return combineLatest(source, input, (x: number, y: number) => {
     return x + y;
   });
 });
開發者ID:angular,項目名稱:zone.js,代碼行數:7,代碼來源:rxjs.Observable.combine.spec.ts

示例8: switchMap

 switchMap(plans => {
   const planDetails = plans.map(plan => {
     return fetchServicePlanDetail(parent.id, plan.name).pipe(
       retry(2),
       map(({ response }) => ({ name: plan.name, ...response }))
     );
   });
   return combineLatest(...planDetails);
 })
開發者ID:dcos,項目名稱:dcos-ui,代碼行數:9,代碼來源:index.ts

示例9: memoize

export const watchFormControl	= memoize((control: FormControl) => concat(
	of(control),
	combineLatest(
		control.statusChanges,
		control.valueChanges
	).pipe(
		map(() => control)
	)
));
開發者ID:cyph,項目名稱:cyph,代碼行數:9,代碼來源:form-controls.ts

示例10: it

  it('should combineLatest the provided observables', () => {
    const firstSource =  hot('----a----b----c----|');
    const secondSource = hot('--d--e--f--g--|');
    const expected =         '----uv--wx-y--z----|';

    const combined = combineLatest(firstSource, secondSource,
      (a, b) => '' + a + b);

    expectObservable(combined).toBe(expected, {u: 'ad', v: 'ae', w: 'af', x: 'bf', y: 'bg', z: 'cg'});
  });
開發者ID:DallanQ,項目名稱:rxjs,代碼行數:10,代碼來源:combineLatest-spec.ts

示例11: ngOnInit

 ngOnInit() {
   this.block$ = combineLatest(
     this.config.currentChain$,
     this.route.paramMap.pipe(
       switchMap(params => of(params.get('hash'))),
       filter((hash): hash is string => typeof hash === 'string')
     )
   ).pipe(
     switchMap(([chain, hash]) => this.apiService.streamBlock(chain, hash))
   );
 }
開發者ID:bitjson,項目名稱:bitcore,代碼行數:11,代碼來源:block.page.ts

示例12: googleSignIn

 googleSignIn() {
   combineLatest(this.auth.signIn(), this.route.queryParams, (res: boolean, param: Params) => {
     return { success: res, redirectTo: param['return'] || '/' };
   })
     .subscribe((signInRes: { success: boolean, redirectTo: string }) => {
       if (signInRes.success) {
         this.router.navigateByUrl(signInRes.redirectTo);
       } else {
         console.error('login failed');
       }
     })
 }
開發者ID:cuponthetop,項目名稱:bg-hub,代碼行數:12,代碼來源:login.component.ts

示例13: ngOnInit

 ngOnInit(): void {
     combineLatest(this.route.parent.url, this.route.params)
         .subscribe((route) => {
             const url = route[0];
             const params = route[1];
             if(url[1].path == 'new') {
                 this.create(params);
             } else {
                 this.load(params['id']);
             }
         });
 }
開發者ID:pigatron-industries,項目名稱:pigatron-web,代碼行數:12,代碼來源:abstractform.component.ts

示例14: queryCosmosForUIVersions

function getUpdateAvailable$() {
  const uiMetaData$ = getUiMetadata$();
  const cosmosVersions$ = queryCosmosForUIVersions();
  return combineLatest<[UIMetadata, Package]>([
    uiMetaData$,
    cosmosVersions$
  ]).pipe(
    map(([uiMetaData, packageInfo]) =>
      versionUpdateAvailable(packageInfo, uiMetaData)
    )
  );
}
開發者ID:dcos,項目名稱:dcos-ui,代碼行數:12,代碼來源:streams.ts

示例15: statusChanges

    get statusChanges(): Observable<any | null> {
        let statusChanges = this.ngControl.statusChanges;

        if (this.parentForm) {
            statusChanges = combineLatest(
                statusChanges,
                this.parentForm.statusChanges,
            );
        }

        return statusChanges;
    }
開發者ID:suiruiw,項目名稱:geeks-diary,代碼行數:12,代碼來源:form-field-control.ts


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