zoukankan      html  css  js  c++  java
  • RxJS之转化操作符 ( Angular环境 )

    一 map操作符

    类似于大家所熟知的 Array.prototype.map 方法,此操作符将投射函数应用于每个值 并且在输出 Observable 中发出投射后的结果。

    import { Component, OnInit } from '@angular/core';
    import { Observable } from 'rxjs/Observable';
    import { of } from 'rxjs/observable/of';
    import { map } from 'rxjs/operators/map';
    
    @Component({
      selector: 'app-convert',
      templateUrl: './convert.component.html',
      styleUrls: ['./convert.component.css']
    })
    export class ConvertComponent implements OnInit {
    
      constructor() { }
    
      ngOnInit() {
        of(1, 2).pipe(map(val => val * 10))
          .subscribe(val => {
            console.log(val);
          });
      }
    
    }

    二 switchMap操作符

    将每个源值映射成 Observable,并输出这个新生成的内部Observable。

    源值发生变化时,停止旧的Observable及其订阅,输出新的Observable。

    import { Component, OnInit } from '@angular/core';
    import { Observable } from 'rxjs/Observable';
    import { interval } from 'rxjs/observable/interval';
    import {map} from 'rxjs/operators/map';
    import { switchMap } from 'rxjs/operators/switchMap';
    
    @Component({
      selector: 'app-convert',
      templateUrl: './convert.component.html',
      styleUrls: ['./convert.component.css']
    })
    export class ConvertComponent implements OnInit {
    
      constructor() { }
    
      ngOnInit() {
        interval(5000)
          .pipe(
            switchMap(
              val => interval(1000)
                .pipe(map(val2 => val * 100 + val2))
            )
          )
          .subscribe(val => {
            console.log(val);
          });
      }
    
    }

     三 mergeMap操作符

    Returns an Observable that emits items based on applying a function that you supply to each item emitted by the source Observable, where that function returns an Observable, and then merging those resulting Observables and emitting the results of this merger.

    import { Component, OnInit } from '@angular/core';
    import { Observable } from 'rxjs/Observable';
    import { of } from 'rxjs/observable/of';
    import { map } from 'rxjs/operators/map';
    import { mergeMap } from 'rxjs/operators/mergeMap';
    
    @Component({
      selector: 'app-combine',
      templateUrl: './combine.component.html',
      styleUrls: ['./combine.component.css']
    })
    export class CombineComponent implements OnInit {
    
      constructor() { }
    
      ngOnInit() {
        of('dog', 'tiger')
          .pipe(mergeMap((outer: string) => {
            return of('cat', 'lion').pipe(
              map((inner: string) => {
                return outer + ' ' + inner;
              }));
          }))
          .subscribe(
            (val: string) => {
              console.log(val);
            }
          );
      }
    }

    处理串行ajax请求 ( safari停止跨域限制 )

    import { Component, OnInit } from '@angular/core';
    import { HttpClient } from '@angular/common/http';
    import { Observable } from 'rxjs/Observable';
    import { of } from 'rxjs/observable/of';
    import { map } from 'rxjs/operators/map';
    import { mergeMap } from 'rxjs/operators/mergeMap';
    
    @Component({
      selector: 'app-combine',
      templateUrl: './combine.component.html',
      styleUrls: ['./combine.component.css']
    })
    export class CombineComponent implements OnInit {
    
      constructor(private http: HttpClient) { }
    
      ngOnInit() {
        this.http.get('https://www.baidu.com', { responseType: 'text' })
          .pipe(mergeMap((baidu: string) => {
            return this.http.get('https://www.sogou.com', { responseType: 'text' })
              .pipe(map((sogou: string) => {
                const baiduTitle = baidu.substring(baidu.indexOf('<title>') + 7, baidu.indexOf('</title>'));
                const sogouTitle = sogou.substring(sogou.indexOf('<title>') + 7, sogou.indexOf('</title>'));
                return [baiduTitle, sogouTitle];
              }));
          }))
          .subscribe((titles: string[]) => {
            console.log(titles);
          });
      }
    }

  • 相关阅读:
    python可变的参数列表
    python函数中的关键字参数
    python中的else子句
    python3中的range函数
    python列表和分片
    jmeter 参数化四种方式
    redis集群和单点可以共存
    localhost与127.0.0.1的区别是什么
    Pytest单元测试框架-Pytest环境安装
    Nginx、HAProxy、LVS三者的优缺点
  • 原文地址:https://www.cnblogs.com/sea-breeze/p/8973000.html
Copyright © 2011-2022 走看看