淺談Fetch 數(shù)據(jù)交互方式
獲取資源很簡單,發(fā)起一個(gè)請求出去,一個(gè)響應(yīng)進(jìn)來,然后該怎么操作就怎么操作。
fetch 的 api 使用的是 promise 規(guī)范,不會(huì) promise(用于延遲(deferred) 計(jì)算和異步(asynchronous ) 計(jì)算。 一個(gè) Promise 對象代表著一個(gè)還未完成,但預(yù)期將來會(huì)完成的操作。主要使用它處理回調(diào)黑洞。) 的請花幾分鐘學(xué)習(xí)一下。
使用 fetch 去獲取數(shù)據(jù)的方式:
fetch("服務(wù)器地址") .then(function(response) { //將獲取到的數(shù)據(jù)使用 json 轉(zhuǎn)換對象 return response.json(); }) .then(function(data) { //獲取轉(zhuǎn)換后的格式 console.log(data); }) //如果有異常會(huì)在 catch 捕獲 .catch(function(e) { console.log("error"); });
有沒有發(fā)現(xiàn)使用 fetch 后代碼變優(yōu)美了,不關(guān)心數(shù)據(jù)怎么請求的,把更多的精力放在處理數(shù)據(jù)上。
不用寫回調(diào)函數(shù)了,也不用監(jiān)聽 xhr readystatechange 事件了,當(dāng)數(shù)據(jù)請求回來后會(huì)傳遞給 then, 有異常就會(huì)直接觸發(fā) catch 事件。
fetch 默認(rèn)發(fā)起的是 get 請求,如果需要 post 請求需要設(shè)置 Request
Request
Request 客戶端向服務(wù)器發(fā)出請求的一個(gè)對象,包括用戶提交的信息以及客戶端的一些信息
使用 Request 構(gòu)造一個(gè) fetch 請求的對象的詳細(xì)信息
//實(shí)例化 request 對象 var myRequest = new Request(url, Option); fetch(myRequest) .then(function(response) { console.log(response); }) //如果有異常會(huì)在 catch 捕獲 .catch(function(e) { console.log("error"); });
Request 詳細(xì)參數(shù)配置:
method
設(shè)置請求方式
method = GET / POST / PUT / DELETE / HEAD
headers
設(shè)置請求頭信息,使用 Headers 對象
let headers = new Headers({ 'Content-Type': 'text/plain' });
mode
請求的模式,主要用于跨域設(shè)置
mode = cors / no-cors / same-origin
cors : 跨域
no-cors : 不跨域
same-origin : 同源
credentials
需要向服務(wù)器發(fā)送 cookie 時(shí)設(shè)置
credentials = omit / same-origin
omit : 省略
same-origin : 發(fā)送同源 cookie
cache
cache = default / reload / no-cache
redirect
收到重定向消息時(shí)如何處理
redirect = follow / error / manual
follow : 跟隨重定向的地址 ,繼續(xù)請求
error : 不請求
比如:
var request = new Request("url", { headers: new Headers({ "Content-Type": "text/plain" }), method : "POST", mode: "cors", redirect : "follow" }); fetch(request) .then((response) => { console.log(response); }) .catch((error)=>{ console.log(error); });
fetch 數(shù)據(jù)處理
當(dāng) fetch 把請求結(jié)果拿到后,我們需要使用它提供的幾個(gè)方法來做處理
json
fetch 提供了一個(gè) json 方法將數(shù)據(jù)轉(zhuǎn)換為 json 格式
fetch(url) .then((response) => { //返回 object 類型 return response.json(); }) .then((result) => { console.log(result); });
text
fetch 提供了一個(gè) text 方法用于獲取數(shù)據(jù),返回的是 string 格式數(shù)據(jù)
fetch(url) .then((response) => { //返回 string 類型 return response.text(); }) .then((result) => { console.log(result); });
blob
如果我們獲取的是一個(gè)圖像,需要先設(shè)置頭信息,然后 fetch 會(huì)正常處理本次請求,最終使用 blob 方法獲取本次請求的結(jié)果, 可以把結(jié)果賦值給 img src 就能正常的顯示一張圖片
var request = new Request("xx.img", { headers: new Headers({ "Content-Type": "image/jpeg" }), method : "get", cache: 'default' }); fetch(request) .then((response) => { return response.blob(); }) .then((stories)=>{ var objectURL = URL.createObjectURL(stories); let img = document.createElement("img"); img.src = objectURL; document.querySelector("body").appendChild(img); });
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
uniapp小程序底部tabbar圖標(biāo)大小設(shè)置辦法
這篇文章主要給大家介紹了關(guān)于uniapp小程序底部tabbar圖標(biāo)大小設(shè)置辦法的相關(guān)資料,在使用uniapp進(jìn)行開發(fā)時(shí),tabbar是我們使用的很頻繁的一個(gè)組件,但是在特定的平臺會(huì)有一些使用上的限制,需要的朋友可以參考下2023-08-08修改layui的后臺模板的左側(cè)導(dǎo)航欄可以伸縮的方法
今天小編就為大家分享一篇修改layui的后臺模板的左側(cè)導(dǎo)航欄可以伸縮的方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09JavaScript中的for循環(huán)與雙重for循環(huán)詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中for循環(huán)與雙重for循環(huán)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03關(guān)于同時(shí)使用swiper和echarts遇到的問題及解決方法
這篇文章主要介紹了關(guān)于同時(shí)使用swiper和echarts遇到的問題及解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04javascript十個(gè)最常用的自定義函數(shù)(中文版)
如果不使用類庫或者沒有自己的類庫,儲備一些常用函數(shù)總是有好處的。2009-09-09