Fetch API

寫在前面

fetchXMLHttpRequest非常類似,都是用來做網(wǎng)絡(luò)請(qǐng)求懂鸵。但是同復(fù)雜的XMLHttpRequestAPI相比财著,fetch提供了更加強(qiáng)大靈活的特性,使用了Promise认罩,這讓它使用起來更加簡潔,從而避免陷入”回調(diào)地獄”。

與XMLHttpRequest的比較

使用XMLHttpRequest來實(shí)現(xiàn)改功能需要設(shè)置兩個(gè)監(jiān)聽函數(shù)澎胡,分別用來處理成功和失敗的情況,同時(shí)還需要依次調(diào)用open()send()方法才能實(shí)現(xiàn)請(qǐng)求。

function reqListener() { 
    var data = JSON.parse(this.responseText); console.log(data);
}
function reqError(err) { 
    console.log('Fetch Error : %S', err);
}
var oReq = new XMLHttpRequest();
oReq.onload = reqListener;
oReq.onerror = reqError;oReq.open('get', './api/some.json', true);
oReq.send();

使用fetch來實(shí)現(xiàn)是這樣的:

fetch('./api/some.json') 
    .then(function(res) { 
        if (res.status !== 200) { 
            console.log('Looks like there was a problem. Status Code: ' + res.status); return; 
        }  
        // 處理響應(yīng)中的文本信息  
        res.json().then(function(data) { 
            console.log(data); 
        }); 
    }) 
    .catch(function(err) { 
        console.log('Fetch Error : %S', err); 
    })

為什么要代替XMLHttpRequest

看了前面的例子攻谁,你可能會(huì)問稚伍,為什么不直接使用那些[現(xiàn)有的XMLHttpRequest
包裝器]呢? 原因在于Fetch API不僅僅為你提供了一個(gè)fetch()方法戚宦。

你可以通過Request構(gòu)造器函數(shù)創(chuàng)建一個(gè)新的請(qǐng)求對(duì)象个曙,這也是建議標(biāo)準(zhǔn)的一部分。 第一個(gè)參數(shù)是請(qǐng)求的URL受楼,第二個(gè)參數(shù)是一個(gè)選項(xiàng)對(duì)象垦搬,用于配置請(qǐng)求。請(qǐng)求對(duì)象一旦創(chuàng)建了艳汽, 你便可以將所創(chuàng)建的對(duì)象傳遞給fetch()方法猴贰,用于替代默認(rèn)的URL字符串。

每個(gè)Request對(duì)象都有一個(gè)header屬性河狐,在Fetch API中它對(duì)應(yīng)了一個(gè)Headers對(duì)象米绕。 通過Headers對(duì)象,你能夠修改請(qǐng)求頭馋艺。不僅如此栅干,對(duì)于返回的響應(yīng),你還能輕松的返回響應(yīng)頭中的各個(gè)屬性丈钙。 但是需要注意的是非驮,響應(yīng)頭是只讀的。

響應(yīng)中的元數(shù)據(jù)

在上面的例子中雏赦,我們可以查看響應(yīng)對(duì)象的狀態(tài)碼劫笙,也知道了如何將響應(yīng)轉(zhuǎn)換成JSON格式的數(shù)據(jù)。但其實(shí)我們可以訪問的元數(shù)據(jù)還有以下這些:

fetch("some.json").then(function(res) { 
     console.log(res.headers.get('Content-Type')); 
     console.log(res.headers.get('Data'));  
     console.log(res.status);               
     console.log(res.statusText);
     console.log(res.type); 
     console.log(res.url);
})

fetch不足之處

Promises缺少了一些重要的XMLHttpRequest的使用場景星岗。例如填大, 使用標(biāo)準(zhǔn)的ES6 Promise你無法收集進(jìn)入信息或中斷請(qǐng)求。但另一方面俏橘,使用XMLHttpRequest你可以模擬進(jìn)度(監(jiān)聽progress事件)允华,也可以取消請(qǐng)求(使用abort()方法)。但是寥掐,如果有必要你也可以使用Promise來包裹它

瀏覽器支持

222.png

demo

本人在實(shí)際項(xiàng)目用到的封裝好的方法,僅供參考

function fetchPost(url ,data) {    
    let host = DIX.HOST + url;    
    let token = UTIL.getToken();    
    let dataUrl = '';    
    if (data)  {        
        for (let item in data)  {            
          if (data.hasOwnProperty(item))  {                
              dataUrl += ('&' + item + '=' + data[item]); 
          }        
        }    
    }    
    let body = 'client=1&version=3&token=' + token + dataUrl;    
    
    return fetch (host, { 
        method: 'POST',        
        headers: {            
            "Content-Type": "application/x-www-form-urlencoded" 
        },        
        body: body    
    }).then(function(res) {        
        if (res.status !== 200) {            
            console.log('Looks like there was a problem. Status Code: ' + res.status);           
            return;       
         }        
        // 處理響應(yīng)中的文本信息        
        return res.json();    
    }).catch(function(err) {      
        console.log('Fetch Error : %S', err);   
     })
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末靴寂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子召耘,更是在濱河造成了極大的恐慌百炬,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件污它,死亡現(xiàn)場離奇詭異剖踊,居然都是意外死亡庶弃,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門德澈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來歇攻,“玉大人,你說我怎么就攤上這事梆造〗墒兀” “怎么了?”我有些...
    開封第一講書人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵澳窑,是天一觀的道長斧散。 經(jīng)常有香客問我,道長摊聋,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任栈暇,我火速辦了婚禮麻裁,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘源祈。我一直安慰自己煎源,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開白布香缺。 她就那樣靜靜地躺著手销,像睡著了一般。 火紅的嫁衣襯著肌膚如雪图张。 梳的紋絲不亂的頭發(fā)上锋拖,一...
    開封第一講書人閱讀 51,573評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音祸轮,去河邊找鬼兽埃。 笑死,一個(gè)胖子當(dāng)著我的面吹牛适袜,可吹牛的內(nèi)容都是我干的柄错。 我是一名探鬼主播,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼苦酱,長吁一口氣:“原來是場噩夢啊……” “哼售貌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起疫萤,我...
    開封第一講書人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤颂跨,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后给僵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毫捣,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡详拙,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蔓同。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片饶辙。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖斑粱,靈堂內(nèi)的尸體忽然破棺而出弃揽,到底是詐尸還是另有隱情,我是刑警寧澤则北,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布矿微,位于F島的核電站,受9級(jí)特大地震影響尚揣,放射性物質(zhì)發(fā)生泄漏涌矢。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一快骗、第九天 我趴在偏房一處隱蔽的房頂上張望娜庇。 院中可真熱鬧,春花似錦方篮、人聲如沸名秀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽匕得。三九已至,卻和暖如春巾表,著一層夾襖步出監(jiān)牢的瞬間汁掠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來泰國打工攒发, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留调塌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓惠猿,卻偏偏與公主長得像羔砾,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子偶妖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理姜凄,服務(wù)發(fā)現(xiàn),斷路器趾访,智...
    卡卡羅2017閱讀 134,657評(píng)論 18 139
  • JavaScript 通過XMLHttpRequest(XHR)來執(zhí)行異步請(qǐng)求态秧,這個(gè)方式已經(jīng)存在了很長一段時(shí)間。雖...
    Bruce_zhuan閱讀 2,456評(píng)論 1 10
  • 本文詳細(xì)介紹了 XMLHttpRequest 相關(guān)知識(shí)扼鞋,涉及內(nèi)容: AJAX申鱼、XMLHTTP愤诱、XMLHttpReq...
    semlinker閱讀 13,662評(píng)論 2 18
  • Fetch API 一個(gè)隱藏最深的秘密就是AJAX的實(shí)現(xiàn)底層的XMLHttpRequest,這個(gè)方法本來并不是造出...
    uncle_charlie閱讀 1,399評(píng)論 0 5
  • fetch 是瀏覽器提供的一個(gè)新的 web API捐友,它用來代替 Ajax(XMLHttpRequest)淫半,其提供了...
    唯泥Bernie閱讀 8,590評(píng)論 0 6