Fetch超時(shí)設(shè)置與終止請(qǐng)求詳解
1.基本使用
Fetch 是一個(gè)新的端獲取資源的接口,用于替換笨重繁瑣XMLHttpRequest.它有了Request 和 Response 以及Headers對(duì)象的概念,與后端語言請(qǐng)求資源更接近。
一個(gè)簡單的GET請(qǐng)求
fetch('https://www.baidu.com') .then(resp=>resp.text()) // 轉(zhuǎn)換成文本對(duì)象 .then(resp=>console.log(resp)) // 輸出請(qǐng)求內(nèi)容 .catch(error => console.error(error));
一個(gè)簡單的POST請(qǐng)求
fetch('https://www.easy-mock.com/mock/5ca59ba44ba86c23d507bd40/example/getUser',{method:"post"}) .then(resp=>resp.json()) //轉(zhuǎn)換成Json對(duì)象 .then(resp=>console.log(resp)) //輸出Json內(nèi)容 .catch(error => console.error(error));
更多Fetch相關(guān)詳細(xì),可查看MDN文檔 developer.mozilla.org/en-US/docs/…
2.超時(shí)設(shè)置
在使用XMLHttpRequest可以設(shè)置請(qǐng)求超時(shí)時(shí)間,可是轉(zhuǎn)用Fetch后,超時(shí)時(shí)間設(shè)置不見了,在網(wǎng)絡(luò)不可靠的情況下,超時(shí)設(shè)置往往很有用
ES6以后Promise 出現(xiàn)解決地獄回調(diào)等不優(yōu)雅的代碼風(fēng)格。個(gè)人理解這個(gè)更像是一個(gè)生產(chǎn)者和消費(fèi)者的關(guān)系,查看 Promise文檔,有以下兩個(gè)方法
- Promise.race([promise1,promise2]) 傳入多個(gè)Promise對(duì)象,等待最快對(duì)象完成
- Promise.all([promise1,promise2]) 傳入多個(gè)Promise 對(duì)象,等待所有對(duì)象完成
有了以上知識(shí)后,結(jié)合函數(shù)setTimeout就可以實(shí)現(xiàn)超時(shí)設(shè)置
//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.取消請(qǐng)求
將上邊的代碼拷貝的瀏覽器控制臺(tái)并將network設(shè)置為Slow3G。運(yùn)行就會(huì)發(fā)現(xiàn),雖然我們?cè)诳刂婆_(tái)看到了超時(shí)信息,但切換到netwok頁簽中發(fā)現(xiàn)請(qǐng)求依然正常進(jìn)行中,并返回了正確的內(nèi)容。這并不是我想要的結(jié)果,我希望超時(shí)時(shí)間到了,請(qǐng)求也應(yīng)該終止。
fetch請(qǐng)求成功后,默認(rèn)返回一個(gè)Response對(duì)象,那么我們?nèi)绾卧诖a中構(gòu)造一個(gè)這樣的對(duì)象呢?
timeoutResp=new Response("timeout", { status: 504, statusText: "timeout " }) successResp=new Response("ok", { status: 200, statusText: "ok " })
AbortController 用于手動(dòng)終止一個(gè)或多個(gè)DOM請(qǐng)求,通過該對(duì)象的AbortSignal注入的Fetch的請(qǐng)求中。所以需要完美實(shí)現(xiàn)timeout功能加上這個(gè)就對(duì)了
//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é)
第一次在項(xiàng)目中使用fetch,在面向API編程的過程中,發(fā)現(xiàn)fetch沒有超時(shí)的設(shè)置。第一時(shí)間查看了MDN文檔以及向搜索引擎找尋實(shí)現(xiàn)功能的靈感(copy+c)。有些朋友在settimeout中通過 reject(new Error('網(wǎng)絡(luò)超時(shí)'))實(shí)現(xiàn)。其實(shí)這樣只是讓前端感知當(dāng)前請(qǐng)求超時(shí)了,并沒有真正終止本次請(qǐng)求。所以必須借助AbortSignal信號(hào)對(duì)象。此功能目前還處于試驗(yàn)階段,使用需謹(jǐn)慎。
demo地址 https://github.com/464884492/blog/blob/master/demo/fetch/fetchdemo.js
好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
js實(shí)現(xiàn)文章文字大小字號(hào)功能完整實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)文章文字大小字號(hào)功能的實(shí)現(xiàn)方法,可根據(jù)用戶習(xí)慣調(diào)整顯示文字的大小.詳細(xì)講述了實(shí)現(xiàn)這一功能的完整步驟.是非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11前端實(shí)現(xiàn)類似chatgpt的對(duì)話頁面(案例)
這篇文章主要介紹了前端實(shí)現(xiàn)類似chatgpt的對(duì)話頁面(案例),需要的朋友可以參考下2023-03-03詳解實(shí)現(xiàn)一個(gè)通用的“劃詞高亮”在線筆記功能
這篇文章主要介紹了實(shí)現(xiàn)一個(gè)通用的“劃詞高亮”在線筆記文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04實(shí)例詳解display:none與visible:hidden的區(qū)別
這篇文章主要介紹了實(shí)例詳解display:none與visible:hidden的區(qū)別的相關(guān)資料,需要的朋友可以參考下2017-03-03JavaScript日期和時(shí)間的格式化及其它常用處理方法
這篇文章主要給大家介紹了關(guān)于JavaScript日期和時(shí)間的格式化及其它常用處理方法,JavaScript中可以使用Date對(duì)象來表示日期和時(shí)間,如果需要格式化日期和時(shí)間,可以使用Date對(duì)象的幾個(gè)方法和一些字符串操作方法來實(shí)現(xiàn),需要的朋友可以參考下2023-09-09JavaScript Event學(xué)習(xí)第二章 Event瀏覽器兼容性
在這一章我將對(duì)重要的事件做一個(gè)概述,包括一些流行的瀏覽器的兼容性問題。2010-02-02highcharts.js數(shù)據(jù)綁定方式代碼實(shí)例
這篇文章主要介紹了highcharts.js數(shù)據(jù)綁定方式代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11javascript從image轉(zhuǎn)換為base64位編碼的String
選擇webview把image以base64位編碼的方式傳給本地應(yīng)用,就不需要再取一次圖片文件了,從而提高了速度2014-07-07