成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

fetch:不一樣的xhr請求

cheng10 / 3428人閱讀

摘要:無論請求成功與否,它都返回一個對象,對應(yīng)請求的??蛇x一個配置項對象,包括所有對請求的設(shè)置。注意或方法的請求不能包含信息。只讀請求所關(guān)聯(lián)的對象。使用一個對象來讀取流中的數(shù)據(jù),并將狀態(tài)改為已使用。

fetch初識

此功能某些瀏覽器尚在開發(fā)中,請參考瀏覽器兼容性表格以得到在不同瀏覽器中適合使用的前綴。由于該功能對應(yīng)的標(biāo)準(zhǔn)文檔可能被重新修訂,所以在未來版本的瀏覽器中該功能的語法和行為可能隨之改變。

Note: 如果不需要支持落后的IE系列瀏覽器,就可以放心大膽的使用吧!
ps: 當(dāng)然也可以使用第三方的polyfill 庫!https://github.com/github/fetch

fetch提供了對于xhr的這種請求中的常見的【請求 Request】、【響應(yīng) Response】兩個對象的定義,就像node發(fā)起一個請求或者響應(yīng)一個請求一樣,創(chuàng)建了request、response兩個實例對象,供使用者獲取整個請求過程中的請求和響應(yīng)信息。

它還提供了一種定義,將 CORS 和 HTTP 原生的頭信息結(jié)合起來,取代了原來那種分離的定義。

fetch() 必須接受一個參數(shù)——資源的路徑。無論請求成功與否,它都返回一個 promise 對象,resolve 對應(yīng)請求的 Response。你也可以傳一個可選的第二個參數(shù)—— init(參考 Request)。

一旦 Response 被返回,就有一些方法可以使用了,比如定義內(nèi)容或者處理方法(參考 Body)。

你也可以通過 Request() 和 Response() 的構(gòu)造函數(shù)直接創(chuàng)建請求和響應(yīng),但是我們不建議這么做。他們應(yīng)該被用于創(chuàng)建其他 API 的結(jié)果(比如,service workers 中的 FetchEvent.respondWith)。

fetch由來

參考:https://developer.mozilla.org...
https://developer.mozilla.org...
https://developer.mozilla.org...
在這里可能需要先說下fetch方法的定義,其最原始的定義是在一個接口叫做GlobalFetch,該接口包含了GlobalFetch.fetch() 方法,Window 和WorkerGlobalScope都實現(xiàn)了GlobalFetch 接口,后來瀏覽器都把這個接口作了修改,形成了新的mixin,也就是WorkerOrGlobalScope,繼而演變?yōu)椋篧indowOrWorkerGlobalScope,WindowOrWorkerGlobalScope混入【mixin】 了對 Window 和WorkerGlobalScope 接口的公共特性的描述【包括常見的setInterval、setTimeout等】。顯然除了下文即將列出的之外,這些接口中的每一個,都可以增加更多的特性。

GlobalFetch =》 WorkerOrGlobalScope =》WindowOrWorkerGlobalScope

Note: WindowOrWorkerGlobalScope 是一個 mixin 而并非 interface。不能創(chuàng)建一個類型為 WindowOrWorkerGlobalScope 的對象。

由于 Window 和WorkerGlobalScope都實現(xiàn)了上述mixin,故而可以放心的在全局域下使用fetch,

fetch概念

Fetch 是一個現(xiàn)代的概念, 等同于 XMLHttpRequest。它提供了許多與XMLHttpRequest相同的功能,但被設(shè)計成更具可擴展性和高效性。
Fetch 的核心在于對 HTTP 接口的抽象,包括 Request,Response,Headers,Body,以及用于初始化異步請求的 global fetch。得益于 JavaScript 實現(xiàn)的這些抽象好的 HTTP 模塊,其他接口能夠很方便的使用這些功能。

Service Workers 是一個利用了 Fetch 實現(xiàn)的接口的例子。

除此之外,F(xiàn)etch 還利用到了請求的異步特性——它是基于 Promise 的。

fettch使用

參考:https://developer.mozilla.org...
https://developer.mozilla.org...
這里先給出一個很簡單的例子,以上代碼中,我們通過網(wǎng)絡(luò)獲取了一個圖片,然后將它插入到一個 標(biāo)簽中。這個最簡單的用法中,fetch() 接受了一個參數(shù)——請求的地址——然后返回一個包含 response(一個 Response 對象)的 promise 對象。:

var myImage = document.querySelector("img");

fetch("flowers.jpg")
.then(function(response) {
  return response.blob();
})
.then(function(myBlob) {
  var objectURL = URL.createObjectURL(myBlob);
  myImage.src = objectURL;
});

這個例子很簡單,不過還是需要先判斷下是否支持fetch:

if(self.fetch) {
    // run my fetch request here
} else {
    // do something with XMLHttpRequest?
}

上面簡單的例子已經(jīng)包含了response對象、blob方法、then方法;后面一一簡述;上面的例子中,fetch函數(shù)只是使用了一個參數(shù),也就是url,即獲取數(shù)據(jù)的后段地址,其實還有第二個參數(shù) init對象;

var myHeaders = new Headers();

var myInit = { method: "GET",
               headers: myHeaders,
               mode: "cors",
               cache: "default" };

fetch("flowers.jpg",myInit)
.then(function(response) {
  return response.blob();
})
.then(function(myBlob) {
  var objectURL = URL.createObjectURL(myBlob);
  myImage.src = objectURL;
});

經(jīng)過進(jìn)一步的完善,fetch使用變成了這個樣子。實際上fetch的定義是這樣的:

Promise fetch(input[, init]);
//another to write the args of fetch 另一種書寫方式
var myRequest = new Request(input, init);
Promise fetch(myRequest);
參數(shù)

參數(shù)的具體介紹:

參數(shù)
input
定義要獲取的資源。這可能是:
一個 USVString 字符串,包含要獲取資源的 URL。一些瀏覽器會接受 blob: 和 data: 作為 schemes.
一個 Request 對象。
init 可選
一個配置項對象,包括所有對請求的設(shè)置。可選的參數(shù)有:
method: 請求使用的方法,如 GET、POST。
headers: 請求的頭信息,形式為 Headers 的對象或包含 ByteString 值的對象字面量。
body: 請求的 body 信息:可能是一個 Blob、BufferSource、FormData、URLSearchParams 或者 USVString 對象。注意 GET 或 HEAD 方法的請求不能包含 body 信息。
mode: 請求的模式,如 cors、 no-cors 或者 same-origin。
credentials: 請求的 credentials,如 omit、same-origin 或者 include。為了在當(dāng)前域名內(nèi)自動發(fā)送 cookie , 必須提供這個選項, 從 Chrome 50 開始, 這個屬性也可以接受 FederatedCredential 實例或是一個 PasswordCredential 實例。
cache:  請求的 cache 模式: default 、 no-store 、 reload 、 no-cache 、 force-cache 或者 only-if-cached 。
redirect: 可用的 redirect 模式: follow (自動重定向), error (如果產(chǎn)生重定向?qū)⒆詣咏K止并且拋出一個錯誤), 或者 manual (手動處理重定向). 在Chrome中,Chrome 47之前的默認(rèn)值是 follow,從 Chrome 47開始是 manual。
referrer: 一個 USVString 可以是 no-referrer、client或一個 URL。默認(rèn)是 client。
referrerPolicy: Specifies the value of the referer HTTP header. May be one of no-referrer、 no-referrer-when-downgrade、 origin、 origin-when-cross-origin、 unsafe-url 。
integrity: 包括請求的  subresource integrity 值 ( 例如: sha256-BpfBw7ivV8q2jLiT13fxDYAe2tJllusRSZ273h2nFSE=)。
返回值
一個 Promise,resolve 時回傳 Response 對象。

Exceptions
Type    Description
TypeError    Since Firefox 43, fetch() will throw a TypeError if the URL has credentials, such as http://user:[email protected].

以上可以看到的就是所有的參數(shù),同樣也是有兩種形式的書寫:

myHeaders = new Headers({
  "Content-Type": "text/plain",
  "Content-Length": content.length.toString(),
  "X-Custom-Header": "ProcessThisImmediately",
});
//它的內(nèi)容可以被獲?。?console.log(myHeaders.has("Content-Type")); // true
console.log(myHeaders.has("Set-Cookie")); // false
myHeaders.set("Content-Type", "text/html");
myHeaders.append("X-Custom-Header", "AnotherValue"); //http 頭部信息
var myInit = { method: "GET",
               headers: myHeaders,
               mode: "cors",
               cache: "default" };

fetch("flowers.jpg",myInit)
.then(function(response) {......
//或者使用這個來構(gòu)建fetch參數(shù),所需的參數(shù)和fetch所需的參數(shù)一樣
var anotherRequest = new Request(input,myInit);

其中的頭部有些需要注意,詳情查看:https://developer.mozilla.org... 可以直接使用Headers構(gòu)建新的請求頭,headers是由鍵值對構(gòu)成,不過有的請求頭只允許用戶代理做修改,詳情參見:https://developer.mozilla.org...
同時Guard也是Headers中的重要部分,由于 Headers 可以在 request 請求中被發(fā)送或者在 response 請求中被接收,并且規(guī)定了哪些參數(shù)是可寫的,Headers 對象有一個特殊的 guard 屬性。這個屬性沒有暴露給 Web,但是它影響到哪些內(nèi)容可以在 Headers 對象中被操作。

可能的值如下:

none:默認(rèn)的

request:從 request 中獲得的 headers(Request.headers)只讀【后端獲取http請求對象】

request-no-cors:從不同域(Request.mode no-cors)的 request 中獲得的 headers 只讀

response:從 response 中獲得的 headers(Response.headers)只讀

immutable:在 ServiceWorkers 中最常用的,所有的 headers 都只讀
下面分別介紹request、body、response

request請求

了解了以上部分后,就知道可以構(gòu)建request來發(fā)起http請求,

myHeaders = new Headers({
  "Content-Type": "text/plain",
  "Content-Length": content.length.toString(),
  "X-Custom-Header": "ProcessThisImmediately",
});
//它的內(nèi)容可以被獲?。?console.log(myHeaders.has("Content-Type")); // true
console.log(myHeaders.has("Set-Cookie")); // false
myHeaders.set("Content-Type", "text/html");
myHeaders.append("X-Custom-Header", "AnotherValue"); //http 頭部信息

//屬性
Request.method 只讀
請求使用的方法 (GET, POST, 等.)
Request.url 只讀
請求使用的 URL。
Request.headers 只讀
請求所關(guān)聯(lián)的 Headers 對象。
Request.context 只讀  
請求的上下文 例如:(例如:audio, image, iframe, 等)
Request.referrer 只讀
請求的來源 (例如:client).
Request.mode 只讀
請求的模式 (例如: cors, no-cors, same-origin).
Request.credentials 只讀
請求的憑證 (例如: omit, same-origin).
Request.redirect 只讀
如何處理重定向模式 (例如: follow, error, or manual)
Request.integrity 只讀
請求內(nèi)容的 subresource integrity 值 (例如: sha256-BpfBw7ivV8q2jLiT13fxDYAe2tJllusRSZ273h2nFSE=).
Request.cache 只讀
請求的緩存模式 (例如: default, reload, no-cache).
Request implements Body, so it also has the following property available to it:

Body.bodyUsed 只讀
指示body是否被使用, 類型為Boolean
body請求正文

不管是請求還是響應(yīng)都能夠包含body對象. body也可以是以下任意類型的實例.

ArrayBuffer
ArrayBufferView (Uint8Array and friends)
Blob/File
string
URLSearchParams
FormData
Body 類定義了以下方法 (這些方法都被 Request 和Response所實現(xiàn))以獲取body內(nèi)容. 這些方法都會返回一個被解析后的promise對象和數(shù)據(jù).

Body.bodyUsed 只讀
包含一個指示body是否被讀取過的 Boolean 值。
方法Edit

Body.arrayBuffer()
使用一個buffer數(shù)組來讀取 Response流中的數(shù)據(jù),并將bodyUsed狀態(tài)改為已使用。
Body.blob()
使用一個Blob對象來讀取 Response流中的數(shù)據(jù),并將bodyUsed狀態(tài)改為已使用?!径M(jìn)制】
Body.formData()
使用一個 FormData 對象來讀取 Response流中的數(shù)據(jù),并將bodyUsed狀態(tài)改為已使用【表單數(shù)據(jù)】。
Body.json()
使用一個 JSON 對象來讀取 Response流中的數(shù)據(jù),并將bodyUsed狀態(tài)改為已使用【json】。
Body.text()
使用一個USVString (文本)
clone() 方法The clone() method of the Request interface creates a copy of the current Request object.

clone() throws a TypeError if the response Body has already been used. In fact, the main reason clone() exists is to allow multiple uses of Body objects (when they are one-use only.)

對象來讀取 Response流中的數(shù)據(jù),并將bodyUsed狀態(tài)改為已使用。比起XHR來,這些方法讓非文本化的數(shù)據(jù)使用起來更加簡單,因為這些方法都被 Request 和Response所實現(xiàn)。

返回 response

如果遇到網(wǎng)絡(luò)故障,fetch() promise 將會 reject,帶上一個 TypeError 對象。雖然這個情況經(jīng)常是遇到了權(quán)限問題或類似問題——比如 404 不是一個網(wǎng)絡(luò)故障。想要精確的判斷 fetch() 是否成功,需要包含 promise resolved 的情況,此時再判斷 Response.ok 是不是為 true。
response的屬性和方法:

Response.type 只讀
包含Response的類型 (例如, basic, cors).
Response.url 只讀
包含Response的URL.
Response.useFinalURL
包含了一個布爾值來標(biāo)示這是否是該Response的最終URL.
Response.status 只讀
包含Response的狀態(tài)碼 (例如, 200 成功).
Response.ok 只讀
包含了一個布爾值來標(biāo)示該Response成功(狀態(tài)碼200-299) 還是失敗.
Response.statusText 只讀
包含了與該Response狀態(tài)碼一致的狀態(tài)信息 (例如, OK對應(yīng)200).
Response.headers 只讀
包含此Response所關(guān)聯(lián)的Headers 對象.
Response 實現(xiàn)了 Body, 所以以下屬性同樣可用:

Body.bodyUsed 只讀
 包含了一個布爾值來標(biāo)示該Response是否讀取過Body.
Response.clone()
創(chuàng)建一個Response對象的克隆
Response.error()
返回一個綁定了網(wǎng)絡(luò)錯誤的新的Response對象
Response.redirect()
用另一個URL創(chuàng)建一個新的 response.
Response 實現(xiàn)了 Body, 所以以下方法同樣可用

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/84470.html

相關(guān)文章

  • fetch使用常見問題及其解決辦法

    首先聲明一下,本文不是要講解fetch的具體用法,不清楚的可以參考MDN fetch教程。 引言 說道fetch就不得不提XMLHttpRequest了,XHR在發(fā)送web請求時需要開發(fā)者配置相關(guān)請求信息和成功后的回調(diào),盡管開發(fā)者只關(guān)心請求成功后的業(yè)務(wù)處理,但是也要配置其他繁瑣內(nèi)容,導(dǎo)致配置和調(diào)用比較混亂,也不符合關(guān)注分離的原則;fetch的出現(xiàn)正是為了解決XHR存在的這些問題。例如下面代碼: f...

    pubdreamcc 評論0 收藏0
  • 初識fetch

    摘要:后面可以跟對象,表示等待才會繼續(xù)下去執(zhí)行,如果被或拋出異常則會被外面的捕獲。沒有獲取狀態(tài)方法,標(biāo)準(zhǔn)沒有提供獲取當(dāng)前狀態(tài)或者的方法。只允許外部傳入成功或失敗后的回調(diào)。這種進(jìn)度通知的功能還沒有用過,暫不知道如何替代。 始終不是很懂fetch的作用,然后查了很多資料,看了一篇不錯的文章,結(jié)合自己之前學(xué)習(xí)的Promise,然后做一篇文章,稍微記錄一下。傳統(tǒng) Ajax 已死,F(xiàn)etch 永生 雖...

    rickchen 評論0 收藏0
  • 分別使用 XHR、jQuery 和 Fetch 實現(xiàn) AJAX

    摘要:本文詳細(xì)講述如何使用原生和來實現(xiàn)。使用可以無刷新地向服務(wù)端發(fā)送請求接收服務(wù)端響應(yīng),并更新頁面。分別要用到的方法和方法。,,都是現(xiàn)在和未來解決異步的標(biāo)準(zhǔn)做法,可以完美搭配使用。這也是使用標(biāo)準(zhǔn)一大好處。 本文詳細(xì)講述如何使用原生 JS、jQuery 和 Fetch 來實現(xiàn) AJAX。 AJAX 即 Asynchronous JavaScript and XML,異步的 JavaScript...

    Julylovin 評論0 收藏0
  • fetch使用常見問題及其解決辦法

    摘要:首先聲明一下,本文不是要講解的具體用法,不清楚的可以參考教程。該模式用于跨域請求但是服務(wù)器不帶響應(yīng)頭,也就是服務(wù)端不支持這也是的特殊跨域請求方式其對應(yīng)的為。 首先聲明一下,本文不是要講解fetch的具體用法,不清楚的可以參考 MDN fetch教程。 fetch默認(rèn)不攜帶cookie 配置其 credentials 項,其有3個值: omit: 默認(rèn)值,忽略cookie的發(fā)送 sam...

    pkwenda 評論0 收藏0
  • 全面分析前端網(wǎng)絡(luò)請求方式

    摘要:請求默認(rèn)會攜帶同源請求的,而跨域請求則不會攜帶,設(shè)置的的屬性為將允許攜帶跨域。類型請求成功后的回調(diào)函數(shù)。另外,同樣提供了在環(huán)境下的支持,可謂是網(wǎng)絡(luò)請求的首選方案。當(dāng)網(wǎng)絡(luò)故障時或請求被阻止時,才會標(biāo)記為,如跨域不存在,網(wǎng)絡(luò)異常等會觸發(fā)。 一、前端進(jìn)行網(wǎng)絡(luò)請求的關(guān)注點 大多數(shù)情況下,在前端發(fā)起一個網(wǎng)絡(luò)請求我們只需關(guān)注下面幾點: 傳入基本參數(shù)(url,請求方式) 請求參數(shù)、請求參數(shù)類型 設(shè)...

    Edison 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<