欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Fetch超時設置與終止請求詳解

 更新時間:2019年05月18日 11:41:06   作者:_herbert  
這篇文章主要給大家介紹了關(guān)于Fetch超時設置與終止請求的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Fetch具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

1.基本使用

Fetch 是一個新的端獲取資源的接口,用于替換笨重繁瑣XMLHttpRequest.它有了Request 和 Response 以及Headers對象的概念,與后端語言請求資源更接近。

一個簡單的GET請求

fetch('https://www.baidu.com')
  .then(resp=>resp.text()) // 轉(zhuǎn)換成文本對象
  .then(resp=>console.log(resp)) // 輸出請求內(nèi)容
  .catch(error => console.error(error));

一個簡單的POST請求

fetch('https://www.easy-mock.com/mock/5ca59ba44ba86c23d507bd40/example/getUser',{method:"post"})
  .then(resp=>resp.json()) //轉(zhuǎn)換成Json對象
  .then(resp=>console.log(resp)) //輸出Json內(nèi)容
  .catch(error => console.error(error));

更多Fetch相關(guān)詳細,可查看MDN文檔 developer.mozilla.org/en-US/docs/

2.超時設置

在使用XMLHttpRequest可以設置請求超時時間,可是轉(zhuǎn)用Fetch后,超時時間設置不見了,在網(wǎng)絡不可靠的情況下,超時設置往往很有用

ES6以后Promise 出現(xiàn)解決地獄回調(diào)等不優(yōu)雅的代碼風格。個人理解這個更像是一個生產(chǎn)者和消費者的關(guān)系,查看 Promise文檔,有以下兩個方法

  1. Promise.race([promise1,promise2]) 傳入多個Promise對象,等待最快對象完成
  2. Promise.all([promise1,promise2]) 傳入多個Promise 對象,等待所有對象完成

有了以上知識后,結(jié)合函數(shù)setTimeout就可以實現(xiàn)超時設置

//ahutor:herbert qq:464884492
let timeoutPromise = (timeout) => {
 return new Promise((resolve, reject) => {
  setTimeout(() => {
   resolve("我是 timeoutPromise,已經(jīng)完成了");
  }, timeout);
 });
}
let requestPromise = (url) => {
 return fetch(url);
};
Promise.race([timeoutPromise(1000), requestPromise("https://www.baidu.com")])
 .then(resp => {
  console.log(resp);
 })
 .catch(error => {
  console.log(error);
 });

3.取消請求

將上邊的代碼拷貝的瀏覽器控制臺并將network設置為Slow3G。運行就會發(fā)現(xiàn),雖然我們在控制臺看到了超時信息,但切換到netwok頁簽中發(fā)現(xiàn)請求依然正常進行中,并返回了正確的內(nèi)容。這并不是我想要的結(jié)果,我希望超時時間到了,請求也應該終止。

fetch請求成功后,默認返回一個Response對象,那么我們?nèi)绾卧诖a中構(gòu)造一個這樣的對象呢?

 timeoutResp=new Response("timeout", { status: 504, statusText: "timeout " })
 successResp=new Response("ok", { status: 200, statusText: "ok " })

AbortController 用于手動終止一個或多個DOM請求,通過該對象的AbortSignal注入的Fetch的請求中。所以需要完美實現(xiàn)timeout功能加上這個就對了

//ahutor:herbert qq:464884492
let controller = new AbortController();
let signal = controller.signal;

let timeoutPromise = (timeout) => {
 return new Promise((resolve, reject) => {
  setTimeout(() => {
   resolve(new Response("timeout", { status: 504, statusText: "timeout " }));
   controller.abort();
  }, timeout);
 });
}
let requestPromise = (url) => {
 return fetch(url, {
  signal: signal
 });
};
Promise.race([timeoutPromise(1000), requestPromise("https://www.baidu.com")])
 .then(resp => {
  console.log(resp);
 })
 .catch(error => {
  console.log(error);
 });

4.總結(jié)

第一次在項目中使用fetch,在面向API編程的過程中,發(fā)現(xiàn)fetch沒有超時的設置。第一時間查看了MDN文檔以及向搜索引擎找尋實現(xiàn)功能的靈感(copy+c)。有些朋友在settimeout中通過 reject(new Error('網(wǎng)絡超時'))實現(xiàn)。其實這樣只是讓前端感知當前請求超時了,并沒有真正終止本次請求。所以必須借助AbortSignal信號對象。此功能目前還處于試驗階段,使用需謹慎。

demo地址 https://github.com/464884492/blog/blob/master/demo/fetch/fetchdemo.js

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論