欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Fetch 數(shù)據(jù)交互方式

 更新時(shí)間:2018年12月20日 14:11:56   作者:cmyoung  
這篇文章主要介紹了淺談Fetch 數(shù)據(jù)交互方式,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

獲取資源很簡(jiǎn)單,發(fā)起一個(gè)請(qǐng)求出去,一個(gè)響應(yīng)進(jìn)來(lái),然后該怎么操作就怎么操作。

fetch 的 api 使用的是 promise 規(guī)范,不會(huì) promise(用于延遲(deferred) 計(jì)算和異步(asynchronous ) 計(jì)算。 一個(gè) Promise 對(duì)象代表著一個(gè)還未完成,但預(yù)期將來(lái)會(huì)完成的操作。主要使用它處理回調(diào)黑洞。) 的請(qǐng)花幾分鐘學(xué)習(xí)一下。

使用 fetch 去獲取數(shù)據(jù)的方式:

fetch("服務(wù)器地址")

  .then(function(response) {

    //將獲取到的數(shù)據(jù)使用 json 轉(zhuǎn)換對(duì)象

    return response.json();

  })

  .then(function(data) {

    //獲取轉(zhuǎn)換后的格式

    console.log(data);

  })

  //如果有異常會(huì)在 catch 捕獲

  .catch(function(e) {

    console.log("error");

  }); 

有沒(méi)有發(fā)現(xiàn)使用 fetch 后代碼變優(yōu)美了,不關(guān)心數(shù)據(jù)怎么請(qǐng)求的,把更多的精力放在處理數(shù)據(jù)上。

不用寫(xiě)回調(diào)函數(shù)了,也不用監(jiān)聽(tīng) xhr readystatechange 事件了,當(dāng)數(shù)據(jù)請(qǐng)求回來(lái)后會(huì)傳遞給 then, 有異常就會(huì)直接觸發(fā) catch 事件。

fetch 默認(rèn)發(fā)起的是 get 請(qǐng)求,如果需要 post 請(qǐng)求需要設(shè)置 Request

Request

Request 客戶(hù)端向服務(wù)器發(fā)出請(qǐng)求的一個(gè)對(duì)象,包括用戶(hù)提交的信息以及客戶(hù)端的一些信息

使用 Request 構(gòu)造一個(gè) fetch 請(qǐng)求的對(duì)象的詳細(xì)信息

//實(shí)例化 request 對(duì)象
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è)置請(qǐng)求方式

method = GET / POST / PUT / DELETE / HEAD 

headers

設(shè)置請(qǐng)求頭信息,使用 Headers 對(duì)象

let headers = new Headers({

  'Content-Type': 'text/plain'

}); 

mode

請(qǐng)求的模式,主要用于跨域設(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ù)請(qǐng)求

error : 不請(qǐng)求

比如:

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 把請(qǐng)求結(jié)果拿到后,我們需要使用它提供的幾個(gè)方法來(lái)做處理

json 

fetch 提供了一個(gè) json 方法將數(shù)據(jù)轉(zhuǎn)換為 json 格式

fetch(url)

  .then((response) => {

    //返回 object 類(lèi)型

    return response.json();

  })

  .then((result) => {

    console.log(result);

  }); 

text

fetch 提供了一個(gè) text 方法用于獲取數(shù)據(jù),返回的是 string 格式數(shù)據(jù)

fetch(url)

  .then((response) => {

    //返回 string 類(lèi)型

    return response.text();

  })

  .then((result) => {

    console.log(result);

  });   

blob

如果我們獲取的是一個(gè)圖像,需要先設(shè)置頭信息,然后 fetch 會(huì)正常處理本次請(qǐng)求,最終使用 blob 方法獲取本次請(qǐng)求的結(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);

  }); 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • uniapp小程序底部tabbar圖標(biāo)大小設(shè)置辦法

    uniapp小程序底部tabbar圖標(biāo)大小設(shè)置辦法

    這篇文章主要給大家介紹了關(guān)于uniapp小程序底部tabbar圖標(biāo)大小設(shè)置辦法的相關(guān)資料,在使用uniapp進(jìn)行開(kāi)發(fā)時(shí),tabbar是我們使用的很頻繁的一個(gè)組件,但是在特定的平臺(tái)會(huì)有一些使用上的限制,需要的朋友可以參考下
    2023-08-08
  • JS擴(kuò)展類(lèi),克隆對(duì)象與混合類(lèi)實(shí)例分析

    JS擴(kuò)展類(lèi),克隆對(duì)象與混合類(lèi)實(shí)例分析

    這篇文章主要介紹了JS擴(kuò)展類(lèi),克隆對(duì)象與混合類(lèi),通過(guò)自定義extend,clone與augment函數(shù)實(shí)例分析了類(lèi)的擴(kuò)展,對(duì)象的克隆與混合類(lèi)相關(guān)實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下
    2016-11-11
  • BootStrap CSS全局樣式和表格樣式源碼解析

    BootStrap CSS全局樣式和表格樣式源碼解析

    這篇文章主要為大家詳細(xì)解析了BootStrap圖片樣式、輔助類(lèi)樣式和CSS組件源碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法

    修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法

    今天小編就為大家分享一篇修改layui的后臺(tái)模板的左側(cè)導(dǎo)航欄可以伸縮的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • JavaScript中的for循環(huán)與雙重for循環(huán)詳解

    JavaScript中的for循環(huán)與雙重for循環(huán)詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript中for循環(huán)與雙重for循環(huán)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 微信小程序返回上一頁(yè)傳參并刷新過(guò)程解析

    微信小程序返回上一頁(yè)傳參并刷新過(guò)程解析

    這篇文章主要介紹了微信小程序返回上一頁(yè)傳參并刷新過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • JS拖拽插件實(shí)現(xiàn)步驟

    JS拖拽插件實(shí)現(xiàn)步驟

    實(shí)現(xiàn)JS拖拽插件主要從六個(gè)方面做介紹:一、js拖拽插件的原理,二、根據(jù)原理實(shí)現(xiàn)的最基本效果,三、代碼抽象與優(yōu)化,四、擴(kuò)展:有效的拖拽元素,五、性能優(yōu)化和總結(jié),六、jquery插件化 ,需要的朋友可以參考下
    2015-08-08
  • 通過(guò)大白話(huà)理解微信小程序獲取授權(quán)

    通過(guò)大白話(huà)理解微信小程序獲取授權(quán)

    最近由于公司需要研究了一下微信小程序的開(kāi)發(fā),特此記錄一下小程序獲取授權(quán)的流程,便于自己理解,下面這篇文章主要給大家介紹了關(guān)于如何通過(guò)大白話(huà)理解微信小程序獲取授權(quán)的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • 關(guān)于同時(shí)使用swiper和echarts遇到的問(wèn)題及解決方法

    關(guān)于同時(shí)使用swiper和echarts遇到的問(wèn)題及解決方法

    這篇文章主要介紹了關(guān)于同時(shí)使用swiper和echarts遇到的問(wèn)題及解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • javascript十個(gè)最常用的自定義函數(shù)(中文版)

    javascript十個(gè)最常用的自定義函數(shù)(中文版)

    如果不使用類(lèi)庫(kù)或者沒(méi)有自己的類(lèi)庫(kù),儲(chǔ)備一些常用函數(shù)總是有好處的。
    2009-09-09

最新評(píng)論