W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗(yàn)值獎勵
使用 Fetch API 來 發(fā)出 HTTP 請求。
fromFetch<T>(input: string | Request
, initWithSelector: RequestInit
& { selector?: (response: Response
) => any; } = {}): Observable
<Response
| T>
輸入 | 您想獲取的資源。 可以是網(wǎng)址或請求對象。 |
---|---|
initWithSelector | 可選的。 默認(rèn)值為 {} 。 類型: RequestInit & { selector?: (response: Response) => any; } 。 |
Observable<Response | T>
:一個 Observable,在訂閱時使用本機(jī)執(zhí)行 HTTP 請求 fetch
功能。 將 Subscription
與綁定在一起以 AbortController
進(jìn)行抓取。
警告 部分提取API仍處于試驗(yàn)階段。 AbortController
是 才能正常運(yùn)行并適當(dāng)使用取消功能。
會自動設(shè)置一個內(nèi)部 AbortController 以便 拆除內(nèi)部 fetch
在訂閱取消時 。
如果 a signal
通過 提供 init
參數(shù) ,則其行為將與通常 fetch
。 如果提供的內(nèi)容 signal
中止, 的錯誤 fetch
通常會拒絕 在那種情況下,將被視為可觀察到的錯誤。
import { of } from 'rxjs';
import { fromFetch } from 'rxjs/fetch';
import { switchMap, catchError } from 'rxjs/operators';
const data$ = fromFetch('https://api.github.com/users?per_page=5').pipe(
switchMap(response => {
if (response.ok) {
// OK return data
return response.json();
} else {
// Server is returning a status requiring the client to try something else.
return of({ error: true, message: `Error ${response.status}` });
}
}),
catchError(err => {
// Network or other error, handle appropriately
console.error(err);
return of({ error: true, message: err.message })
})
);
data$.subscribe({
next: result => console.log(result),
complete: () => console.log('done')
});
對于使用 HTTP 響應(yīng) 分塊傳輸編碼的 , 返回的諾言 fetch
將在響應(yīng)的標(biāo)頭被解析后立即解析 收到。
這意味著 fromFetch
可觀察者將發(fā)出 Response
-并將 然后完成-在收到尸體之前。 當(dāng)其中一種方法 Response
-如 text()
或 json()
-被調(diào)用,返回的諾言將不會 解決,直到收到全身。 取消訂閱任何可觀察到的 使用 promise 作為可觀察輸入的操作不會中止請求。
為了便于中止使用分塊傳輸編碼的響應(yīng)的檢索, 一個 selector
可以通過指定 init
參數(shù):
import { of } from 'rxjs';
import { fromFetch } from 'rxjs/fetch';
const data$ = fromFetch('https://api.github.com/users?per_page=5', {
selector: response => response.json()
});
data$.subscribe({
next: result => console.log(result),
complete: () => console.log('done')
});
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: