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


TypeScript Observable.combineLatest方法代碼示例

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


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

示例1: initObservable

export function initObservable() {

    const click$ = Observable.fromEvent(document,'click');

    const mouse$ = Observable.fromEvent(document,'mousemove')
        .filter((move:MouseEvent) => move.clientY >=200);


    const combined$ = Observable.combineLatest(mouse$, click$);

    combined$.subscribe(
        combined => console.log(combined[0])
    );
}
開發者ID:frozentp,項目名稱:courses,代碼行數:14,代碼來源:init-observable.ts

示例2: constructor

 constructor(
     private store: Store<any>
 ){
     this.viewModel$ = Observable.combineLatest(
         store.select('todos'),
         store.select('visibilityFilter'),
         ({past = [], present = [], future = []}, visibilityFilter : string) => {
             return {
                 todos: this.visibleTodos(present, visibilityFilter),
                 totalTodos: present.length,
                 completedTodos: present.filter((todo : Todo) => todo.completed).length
             }
         }
     );
 }
開發者ID:Hongbo-Miao,項目名稱:ngrx-examples,代碼行數:15,代碼來源:todos-viewmodel.ts

示例3: constructor

 constructor(
     private store: Store<any>
 ){
     this.viewModel$ = Observable.combineLatest(
         store.select('todos'),
         store.select('visibilityFilter'),
         (todos : Array<Todo>, visibilityFilter : string) => {
             return {
                 todos: this.visibleTodos(todos, visibilityFilter),
                 totalTodos: todos.length,
                 completedTodos: todos.filter((todo : Todo) => todo.completed).length
             }
         }
     );
 }
開發者ID:justdaft,項目名稱:ngrx-examples,代碼行數:15,代碼來源:todos-viewmodel.ts

示例4: typeahead

export function typeahead(element: ElementRef, minLength = 1, debounceTime = 250): Observable<string> {
    return Observable.combineLatest(
        Observable.merge(
            Observable.fromEvent(element.nativeElement, 'compositionstart').map(() => true),
            Observable.fromEvent(element.nativeElement, 'compositionend').map(() => false),
        ).startWith(false),
        Observable.fromEvent(element.nativeElement, 'keyup'),
    )
    .filter(array => !array[0])
    .map(array => array[1])
    .map((event: KeyboardEvent) => (event.target as HTMLInputElement).value)
    .debounceTime(debounceTime)
    .distinctUntilChanged()
    .filter(value => value.length >= minLength);
}
開發者ID:Gitjerryzhong,項目名稱:bell-tm-static,代碼行數:15,代碼來源:typeahead.ts

示例5: constructor

 constructor(
   private store: Store<any>
   ) {
   this.viewModel$ = Observable.combineLatest(
     store.select('games'),
     store.select('visibilityFilter'),
     (games: Array<IGame>, visibilityFilter: string) => {
       return {
         games: this.visibleGames(games, visibilityFilter),
         totalGames: games.length,
         completedGames: games.filter((game: Game) => game.completed).length
       }
     }
     );
 }
開發者ID:justdaft,項目名稱:super-duper-guacamole,代碼行數:15,代碼來源:todos-viewmodel.ts

示例6: ngOnInit

  ngOnInit() {

    Observable.combineLatest([
      this.route.paramMap,
      this.route.queryParamMap
    ])
    .switchMap(combined => {
      let id = combined[0].get('id');
      let page = combined[1].get('page');

      return this.service.getAll();
    })
    .subscribe(followers => this.followers = followers);
  
      
    }
開發者ID:krzysztofkarp,項目名稱:udemy-angular,代碼行數:16,代碼來源:github-followers.component.ts

示例7: function

/**
 * compute ratio
 */
export default function(options: ResponsiveOptions) {

  const scaleSubject = new BehaviorSubject<any>(true);
  const scaleFn = compose(centeringOf(options.target), scalingOf(options.target));

  const hRatio = scaleSubject.map(horizontalRatioOf(options.width));
  const vRatio = scaleSubject.map(verticalRatioOf(options.height));

  const currentRatio = Observable.combineLatest(hRatio, vRatio).map((hv) => Math.min(hv[0], hv[1]));
  currentRatio.subscribe(scaleFn);

  return {
    scale        : scaleSubject,
    currentRatio : currentRatio
  };
}
開發者ID:1000ch,項目名稱:Talkie,代碼行數:19,代碼來源:responsive.ts

示例8: Date

      .subscribe(data => {

        // map source format to time series data
        let mapped = data.map(single => {
          let typed:TimeSeriesData = {
            value : single[1],
            date : new Date(single[0])
          }
          return typed;
        });

        // store data
        this.data = mapped;


        // DEBUG - we could map the data to percentual changes to the last quarter and offer this as another option...
        // let change = this.data.map(d => d.value).map((value, index, array) => index == 0 ? 0 : value / array[index-1] - 1);
        // console.warn(change);


        // store all years for which we have data
        this.years = this.data
          .map(tsd => tsd.date.getUTCFullYear())
          .filter((elem, pos, arr) => arr.indexOf(elem) == pos);

        // ensure that from <= to in all cases
        this.yearFrom.valueChanges.subscribe(newFrom => {
          if (this.yearTo.value < newFrom)
            this.yearTo.updateValue(newFrom);
        });
        this.yearTo.valueChanges.subscribe(newTo => {
          if (this.yearFrom.value > newTo)
            this.yearFrom.updateValue(newTo);
        });
        
        // whenever one of the years (from,to) change, update the filtered data
        Observable.combineLatest(this.yearFrom.valueChanges, this.yearTo.valueChanges)
          .debounceTime(50)
          .subscribe(yearRange => {
            let from:number = yearRange[0];
            let to:number = yearRange[1];
            this.filteredData = this.data.filter(dataPoint => dataPoint.date.getUTCFullYear() >= from && dataPoint.date.getUTCFullYear() <= to);
          });

        // set initial values to first and last available year
        this.showAllData();
      });
開發者ID:thorstenschaefer,項目名稱:d3-playground,代碼行數:47,代碼來源:gdp.component.ts

示例9: getCantonOptions

    getCantonOptions(): Observable<IMultiSelectOption[]> {
        const mapToOption = (key: string) => ({
            id: key,
            name: `global.reference.canton.${key}`
        });

        const translateOption = (option: IMultiSelectOption) => {
            return this.translateService.stream(option.name)
                .map((translation) => Object.assign({}, option, { name: translation }));
        };
        const translatedOptions = Object.keys(Canton)
            .filter((key) => !isNaN(Number(Canton[key])))
            .map(mapToOption)
            .map(translateOption);

        return Observable.combineLatest(translatedOptions);
    }
開發者ID:alv-ch,項目名稱:job-room,代碼行數:17,代碼來源:canton.service.ts

示例10: it

    it('should work', () => {
      const subjectA = new Subject<string>();
      const subjectB = new Subject<string>();
      const log: string[] = [];
      const subject = Observable.combineLatest(subjectA, subjectB).subscribe(([a, b]) => {
        log.push(`${a}-${b}`);
      });

      subjectA.next('hello');
      expect(log).toEqual([]);

      subjectB.next('world');
      expect(log).toEqual(['hello-world']);

      subjectA.next('bye');
      expect(log).toEqual(['hello-world', 'bye-world']);
    });
開發者ID:loki2302,項目名稱:html5-experiment,代碼行數:17,代碼來源:rxjs.spec.ts


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