<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

        angular.js4使用 RxJS 處理多個 Http 請求

        來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:29:01
        文檔

        angular.js4使用 RxJS 處理多個 Http 請求

        angular.js4使用 RxJS 處理多個 Http 請求:有時候進(jìn)入某個頁面時,我們需要從多個 API 地址獲取數(shù)據(jù)然后進(jìn)行顯示。管理多個異步數(shù)據(jù)請求會比較困難,但我們可以借助 Angular Http 服務(wù)和 RxJS 庫提供的功能來實(shí)現(xiàn)上述的功能。處理多個請求有多種方式,使用串行或并行的方式。 基礎(chǔ)知識 merge
        推薦度:
        導(dǎo)讀angular.js4使用 RxJS 處理多個 Http 請求:有時候進(jìn)入某個頁面時,我們需要從多個 API 地址獲取數(shù)據(jù)然后進(jìn)行顯示。管理多個異步數(shù)據(jù)請求會比較困難,但我們可以借助 Angular Http 服務(wù)和 RxJS 庫提供的功能來實(shí)現(xiàn)上述的功能。處理多個請求有多種方式,使用串行或并行的方式。 基礎(chǔ)知識 merge

        有時候進(jìn)入某個頁面時,我們需要從多個 API 地址獲取數(shù)據(jù)然后進(jìn)行顯示。管理多個異步數(shù)據(jù)請求會比較困難,但我們可以借助 Angular Http 服務(wù)和 RxJS 庫提供的功能來實(shí)現(xiàn)上述的功能。處理多個請求有多種方式,使用串行或并行的方式。

        基礎(chǔ)知識

        mergeMap

        mergeMap 操作符用于從內(nèi)部的 Observable 對象中獲取值,然后返回給父級流對象。

        合并 Observable 對象

        const source = Rx.Observable.of('Hello');
        //map to inner observable and flatten
        const example = source.mergeMap(val => Rx.Observable.of(`${val} World!`));
        
        const subscribe = example.subscribe(val => console.log(val)); //output: 'Hello World!'
        
        

        在上面示例中包含兩種 Observable 類型:

      1. 源 Observable 對象 - 即 source 對象
      2. 內(nèi)部 Observable 對象 - 即 Rx.Observable.of(`${val} World!`) 對象
      3. 僅當(dāng)內(nèi)部的 Observable 對象發(fā)出值后,才會合并源 Observable 對象輸出的值,并最終輸出合并的值。

        forkJoin

        forkJoin 是 Rx 版本的 Promise.all(),即表示等到所有的 Observable 都完成后,才一次性返回值。

        合并多個 Observable 對象

        const getPostOne$ = Rx.Observable.timer(1000).mapTo({id: 1});
        const getPostTwo$ = Rx.Observable.timer(2000).mapTo({id: 2});
        
        Rx.Observable.forkJoin(getPostOne$, getPostTwo$).subscribe(
         res => console.log(res) // [{id: 1}, {id: 2}]
        ); 
        

        處理 Http 請求

        我們先來看一下 Angular Http 服務(wù)簡單示例。

        import { Component, OnInit } from '@angular/core';
        import { Http } from '@angular/http';
        
        import 'rxjs/add/operator/map';
        
        @Component({
         selector: 'app-root',
         template: `
         <p>HttpModule Demo</p>
         `
        })
        export class AppComponent implements OnInit {
         constructor(private http: Http) { }
        
         ngOnInit() {
         this.http.get('https://jsonplaceholder.typicode.com/users')
         .map(res => res.json())
         .subscribe(users => console.log(users));
         }
        }
        
        

        上面示例中,我們通過依賴注入方式注入 http 服務(wù),然后在 ngOnInit() 方法中調(diào)用 http 對象的 get() 方法來獲取數(shù)據(jù)。這個例子很簡單,它只處理一個請求,接下來我們來看一下如何處理兩個請求。

        Map 和 Subscribe

        有些時候,當(dāng)我們發(fā)送下一個請求時,需要依賴于上一個請求的數(shù)據(jù)。即我們在需要在上一個請求的回調(diào)函數(shù)中獲取相應(yīng)數(shù)據(jù),然后在發(fā)起另一個 HTTP 請求。

        import { Component, OnInit } from '@angular/core';
        import { Http } from '@angular/http';
        import 'rxjs/add/operator/map';
        
        @Component({
         selector: 'app-root',
         template: `
         <p>{{username}} Detail Info</p>
         {{user | json}}
         `
        })
        export class AppComponent implements OnInit {
         constructor(private http: Http) { }
        
         apiUrl = 'https://jsonplaceholder.typicode.com/users';
         username: string = '';
         user: any;
        
         ngOnInit() {
         this.http.get(this.apiUrl)
         .map(res => res.json())
         .subscribe(users => {
         let username = users[6].username;
         this.http.get(`${this.apiUrl}?username=${username}`)
         .map(res => res.json())
         .subscribe(
         user => {
         this.username = username;
         this.user = user;
         });
         });
         }
        }
        
        

        在上面示例中,我們先從 https://jsonplaceholder.typicode.com/users 地址獲取所有用戶的信息,然后再根據(jù)指定用戶的 username 進(jìn)一步獲取用戶的詳細(xì)信息。雖然功能實(shí)現(xiàn)了,但有沒有更好的解決方案呢?答案是有的,可以通過 RxJS 庫中提供的 mergeMap 操作符來優(yōu)化上述的流程。

        mergeMap

        import { Component, OnInit } from '@angular/core';
        import { Http } from '@angular/http';
        import 'rxjs/add/operator/map';
        import 'rxjs/add/operator/mergeMap';
        
        @Component({
         selector: 'app-root',
         template: `
         <p>{{username}} Detail Info</p>
         {{user | json}}
         `
        })
        export class AppComponent implements OnInit {
         constructor(private http: Http) { }
        
         apiUrl = 'https://jsonplaceholder.typicode.com/users';
        
         username: string = '';
        
         user: any;
        
         ngOnInit() {
         this.http.get(this.apiUrl)
         .map(res => res.json())
         .mergeMap(users => {
         this.username = users[6].username;
         return this.http.get(`${this.apiUrl}?username=${this.username}`)
         .map(res => res.json())
         })
         .subscribe(user => this.user = user);
         }
        }
        
        

        在上面示例中,我們通過 mergeMap 操作符,解決了嵌套訂閱的問題。最后我們來看一下如何處理多個并行的 Http 請求。

        forkJoin

        接下來的示例,我們將使用 forkJoin 操作符。如果你熟悉 Promises 的話,該操作符與 Promise.all() 實(shí)現(xiàn)的功能類似。forkJoin 操作符接收一個 Observable 對象列表,然后并行地執(zhí)行它們。一旦列表的 Observable 對象都發(fā)出值后,forkJoin 操作符返回的 Observable 對象會發(fā)出新的值,即包含所有 Observable 對象輸出值的列表。具體示例如下:

        import { Component, OnInit } from '@angular/core';
        import { Http } from '@angular/http';
        
        import { Observable } from 'rxjs/Observable';
        import 'rxjs/add/operator/map';
        import 'rxjs/add/observable/forkJoin';
        
        @Component({
         selector: 'app-root',
         template: `
         <p>Post Detail Info</p>
         <ul>
         <li>{{post1 | json}}</li>
         <li>{{post2 | json}}</li>
         </ul>
         `
        })
        export class AppComponent implements OnInit {
         constructor(private http: Http) { }
        
         apiUrl = 'https://jsonplaceholder.typicode.com/posts';
        
         post1: any;
        
         post2: any;
        
         ngOnInit() {
         let post1 = this.http.get(`${this.apiUrl}/1`);
         let post2 = this.http.get(`${this.apiUrl}/2`);
        
         Observable.forkJoin([post1, post2])
         .subscribe(results => {
         this.post1 = results[0];
         this.post2 = results[1];
         });
         }
        }
        
        

        我有話說

        除了 mergeMap 外,RxJS 中的 switchMap 有什么用?

        switchMap 操作符用于對源 Observable 對象發(fā)出的值,做映射處理。若有新的 Observable 對象出現(xiàn),會在新的 Observable 對象發(fā)出新值后,退訂前一個未處理完的 Observable 對象。

        使用示例:

        var source = Rx.Observable.fromEvent(document.body, 'click');
        var example = source.switchMap(e => Rx.Observable.interval(100).take(3));
        
        example.subscribe({
         next: (value) => { console.log(value); },
         error: (err) => { console.log('Error: ' + err); },
         complete: () => { console.log('complete'); }
        });
        
        

        示例 marble 圖:

        source : -----------c--c-----------------...
         concatMap(c => Rx.Observable.interval(100).take(3))
        example: -------------0--0-1-2-----------...

        以上代碼運(yùn)行后,控制臺的輸出結(jié)果:

        0
        0
        1
        2

        而在實(shí)際使用 Http 服務(wù)的場景中,比如實(shí)現(xiàn) AutoComplete 功能,我們可以利用 switchMap 操作符,來取消無用的 Http 請求。

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        angular.js4使用 RxJS 處理多個 Http 請求

        angular.js4使用 RxJS 處理多個 Http 請求:有時候進(jìn)入某個頁面時,我們需要從多個 API 地址獲取數(shù)據(jù)然后進(jìn)行顯示。管理多個異步數(shù)據(jù)請求會比較困難,但我們可以借助 Angular Http 服務(wù)和 RxJS 庫提供的功能來實(shí)現(xiàn)上述的功能。處理多個請求有多種方式,使用串行或并行的方式。 基礎(chǔ)知識 merge
        推薦度:
        標(biāo)簽: 使用 請求 http
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 久久亚洲精品国产亚洲老地址| 亚洲Av高清一区二区三区| 免费的黄色网页在线免费观看| 免费a级毛片高清视频不卡| 亚洲a∨无码男人的天堂| 亚洲国产精品免费在线观看| 亚洲高清日韩精品第一区| 69精品免费视频| 亚洲剧场午夜在线观看| 免费AA片少妇人AA片直播| 香蕉大伊亚洲人在线观看| 香蕉视频在线观看免费国产婷婷| 亚洲AV女人18毛片水真多| 亚洲?v女人的天堂在线观看| jizz免费一区二区三区| 国产亚洲3p无码一区二区| 最近最好最新2019中文字幕免费| 91亚洲国产成人久久精品网址| 18禁成年无码免费网站无遮挡| 亚洲另类自拍丝袜第五页| 亚洲国产一级在线观看| 中国一级毛片视频免费看| 亚洲自偷自偷精品| 午夜免费福利影院| 国产精品1024在线永久免费| 亚洲av永久无码精品网站| 国产无人区码卡二卡三卡免费| 亚洲av乱码一区二区三区按摩| 国产AV无码专区亚洲AV漫画| 99re6热视频精品免费观看| 亚洲精品亚洲人成在线| 久久亚洲精品无码播放| 免费观看无遮挡www的小视频| 国产精品观看在线亚洲人成网| 亚洲色婷婷一区二区三区| 一二三四视频在线观看中文版免费 | 国产亚洲女在线线精品| 免费一级毛片不卡在线播放| 岛国精品一区免费视频在线观看| 8x成人永久免费视频| 亚洲国产精品无码久久一区二区|