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

資訊專欄INFORMATION COLUMN

Fetch()

lakeside / 519人閱讀

摘要:常見(jiàn)的坑接收到表示錯(cuò)誤的狀態(tài)碼時(shí),返回的不會(huì)被標(biāo)記為即使?fàn)顟B(tài)碼為或。會(huì)將狀態(tài)標(biāo)記為但返回值但屬性設(shè)置為。網(wǎng)絡(luò)故障或請(qǐng)求被阻止才會(huì)標(biāo)記為。原始請(qǐng)求請(qǐng)求使用箭頭函數(shù)獲取一個(gè)文件,并打印到控制臺(tái)。參數(shù)接受第二個(gè)可選參數(shù),控制不同配置的參數(shù)。

Fetch()提供了一種方式進(jìn)行跨網(wǎng)絡(luò)異步請(qǐng)求資源的方式,用于訪問(wèn)和操作HTTP管道的部分,比如:請(qǐng)求和相應(yīng)

fetch常見(jiàn)的坑:

接收到表示錯(cuò)誤的HTTP狀態(tài)碼時(shí),fetch()返回的Promise不會(huì)被標(biāo)記為reject(即使?fàn)顟B(tài)碼為404或500)。fetch()會(huì)將Promise狀態(tài)標(biāo)記為resolve(但resolve返回值但OK 屬性設(shè)置為 false)。網(wǎng)絡(luò)故障或請(qǐng)求被阻止才會(huì)標(biāo)記為reject。

fetch()不會(huì)從服務(wù)端發(fā)送或接收任何cookies。發(fā)送cookies 需要設(shè)置 fetch(url, {credentials: "include"}) 選項(xiàng)。

原始XHR請(qǐng)求
var xhr = new XMLHttpRequest();
xhr.open("GET", url);
xhr.responseType = "json";

xhr.onload = function() {
  console.log(xhr.response);
};

xhr.onerror = function() {
  console.log("Oops, error");
};

xhr.send();
fetch請(qǐng)求
fetch(url).then(function(response) {
  return response.json();
}).then(function(data) {
  console.log(data);
}).catch(function(e) {
  console.log("Oops, error");
});

使用箭頭函數(shù):

fetch(url).then(response => response.json())
  .then(data => console.log(data))
  .catch(e => console.log("Oops, error", e))

獲取一個(gè)JSON文件,并打印到控制臺(tái)。指明資源路徑,然后返回一個(gè)Response對(duì)象,使用json()方法獲取JSON但內(nèi)容。

fetch參數(shù)

fetch()接受第二個(gè)可選參數(shù),控制不同配置的init參數(shù)。

// Example POST method implementation:

postData("http://example.com/answer", {answer: 42})
  .then(data => console.log(data)) // JSON from `response.json()` call
  .catch(error => console.error(error))

function postData(url, data) {
  // Default options are marked with *
  return fetch(url, {
    body: JSON.stringify(data), // must match "Content-Type" header
    cache: "no-cache", // *default, no-cache, reload, force-cache, only-if-cached
    credentials: "same-origin", // include, same-origin, *omit
    headers: {
      "user-agent": "Mozilla/4.0 MDN Example",
      "content-type": "application/json"
    },
    method: "POST", // *GET, POST, PUT, DELETE, etc.
    mode: "cors", // no-cors, cors, *same-origin
    redirect: "follow", // manual, *follow, error
    referrer: "no-referrer", // *client, no-referrer
  })
  .then(response => response.json()) // parses response to JSON
}
包含憑據(jù)的請(qǐng)求

包含憑據(jù)的請(qǐng)求:

fetch("https://example.com", {
    //將credentials: "include"添加到傳遞給fetch()方法的init對(duì)象
    credentials: "include" 
})

若在同源櫥發(fā)送憑據(jù):

fetch("https://example.com", {
  credentials: "same-origin"  
})

確保瀏覽器不在請(qǐng)求中包含憑據(jù):

fetch("https://example.com", {
  credentials: "omit"  
})
上傳JSON數(shù)據(jù)
var url = "https://example.com/profile";
var data = {username: "example"};

fetch(url, {
  method: "POST", // or "PUT"
  body: JSON.stringify(data), // data can be `string` or {object}!
  headers: new Headers({
    "Content-Type": "application/json"
  })
}).then(res => res.json())
.catch(error => console.error("Error:", error))
.then(response => console.log("Success:", response));
上傳文件

使用 FormData()fetch()

Headers

使用Headers構(gòu)造函數(shù)創(chuàng)建headers對(duì)象,headers對(duì)象為多鍵值對(duì):

var content = "Hello World";
var myHeaders = new Headers();
myHeaders.append("Content-Type", "text/plain");
myHeaders.append("Content-Length", content.length.toString());
myHeaders.append("X-Custom-Header", "ProcessThisImmediately");

內(nèi)容可被獲?。?/p>

console.log(myHeaders.has("Content-Type")); // true
console.log(myHeaders.has("Set-Cookie")); // false
總結(jié)一下,F(xiàn)etch 優(yōu)點(diǎn)主要有:

語(yǔ)法簡(jiǎn)潔,更加語(yǔ)義化

基于標(biāo)準(zhǔn) Promise 實(shí)現(xiàn),支持 async/await

同構(gòu)方便,使用 isomorphic-fetch

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

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

相關(guān)文章

  • fetch使用的常見(jiàn)問(wèn)題及其解決辦法

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

    pubdreamcc 評(píng)論0 收藏0
  • 傳統(tǒng) Ajax 已死,Fetch 永生

    摘要:結(jié)果證明,對(duì)于以上瀏覽器,在生產(chǎn)環(huán)境使用是可行的。后面可以跟對(duì)象,表示等待才會(huì)繼續(xù)向下執(zhí)行,如果被或拋出異常則會(huì)被外面的捕獲。,,都是現(xiàn)在和未來(lái)解決異步的標(biāo)準(zhǔn)做法,可以完美搭配使用。這也是使用標(biāo)準(zhǔn)一大好處。只允許外部傳入成功或失敗后的回調(diào)。 showImg(https://cloud.githubusercontent.com/assets/948896/10188666/bc9a53...

    fai1017 評(píng)論0 收藏0
  • fetch使用的常見(jiàn)問(wèn)題及其解決辦法

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

    pkwenda 評(píng)論0 收藏0
  • 對(duì)python并發(fā)編程的思考

    摘要:我們以請(qǐng)求網(wǎng)絡(luò)服務(wù)為例,來(lái)實(shí)際測(cè)試一下加入多線程之后的效果。所以,執(zhí)行密集型操作時(shí),多線程是有用的,對(duì)于密集型操作,則每次只能使用一個(gè)線程。說(shuō)到這里,對(duì)于密集型,可以使用多線程或者多進(jìn)程來(lái)提高效率。 為了提高系統(tǒng)密集型運(yùn)算的效率,我們常常會(huì)使用到多個(gè)進(jìn)程或者是多個(gè)線程,python中的Threading包實(shí)現(xiàn)了線程,multiprocessing 包則實(shí)現(xiàn)了多進(jìn)程。而在3.2版本的py...

    sshe 評(píng)論0 收藏0
  • fetch,終于認(rèn)識(shí)你

    摘要:說(shuō)明一點(diǎn),下面演示的請(qǐng)求或請(qǐng)求,都是采用百度中查詢到的一些接口,可能傳遞的有些參數(shù)這個(gè)接口并不會(huì)解析,但不會(huì)影響這個(gè)接口的使用。 fetch和XMLHttpRequest 如果看網(wǎng)上的fetch教程,會(huì)首先對(duì)比XMLHttpRequest和fetch的優(yōu)劣,然后引出一堆看了很快會(huì)忘記的內(nèi)容(本人記性不好)。因此,我寫(xiě)一篇關(guān)于fetch的文章,為了自己看著方便,畢竟工作中用到的也就是一些...

    wzyplus 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<