91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Fetch怎么實現超時設置與終止請求

發布時間:2021-05-25 17:41:51 來源:億速云 閱讀:160 作者:Leah 欄目:web開發

使用Fetch怎么實現超時設置與終止請求?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

1.基本使用

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

一個簡單的GET請求

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

一個簡單的POST請求

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

更多Fetch相關詳細,可查看MDN文檔 developer.mozilla.org/en-US/docs/…

2.超時設置

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

ES6以后Promise 出現解決地獄回調等不優雅的代碼風格。個人理解這個更像是一個生產者和消費者的關系,查看 Promise文檔,有以下兩個方法

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

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

有了以上知識后,結合函數setTimeout就可以實現超時設置

//ahutor:herbert qq:464884492
let timeoutPromise = (timeout) => {
 return new Promise((resolve, reject) => {
  setTimeout(() => {
   resolve("我是 timeoutPromise,已經完成了");
  }, 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。運行就會發現,雖然我們在控制臺看到了超時信息,但切換到netwok頁簽中發現請求依然正常進行中,并返回了正確的內容。這并不是我想要的結果,我希望超時時間到了,請求也應該終止。

fetch請求成功后,默認返回一個Response對象,那么我們如何在代碼中構造一個這樣的對象呢?

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

AbortController 用于手動終止一個或多個DOM請求,通過該對象的AbortSignal注入的Fetch的請求中。所以需要完美實現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);
 });

關于使用Fetch怎么實現超時設置與終止請求問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

洛宁县| 蛟河市| 洛浦县| 乐平市| 青铜峡市| 永兴县| 栾城县| 巴东县| 武鸣县| 如东县| 高尔夫| 开江县| 彭泽县| 台南县| 纳雍县| 孝昌县| 吴桥县| 涪陵区| 玉门市| 苏尼特右旗| 闵行区| 清远市| 加查县| 丰原市| 长白| 镇宁| 玉屏| 出国| 读书| 工布江达县| 怀来县| 桃园县| 澳门| 丰城市| 灵璧县| 南靖县| 洪洞县| 汽车| 衡东县| 虎林市| 静宁县|