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

資訊專欄INFORMATION COLUMN

JS HTTP 請求終極解決方案 - fly.js

OpenDigg / 3352人閱讀

摘要:支持請求響應(yīng)攔截器。定位與目標(biāo)的定位是成為請求的終極解決方案。攔截器支持請求響應(yīng)攔截器,可以通過它在請求發(fā)起之前和收到響應(yīng)數(shù)據(jù)之后做一些預(yù)處理。

Fly.js 是一個功能強大的輕量級的javascript http請求庫,同時支持瀏覽器和node環(huán)境,通過適配器,它可以運行在任何具有網(wǎng)絡(luò)能力的javascript運行環(huán)境;同時fly.js有一些高級的玩法如全局ajax攔截、在web app中支持請求重定向等,耐心看下去,它會給你足夠的驚喜。

接下來會出幾篇文章深入的介紹fly.js的高級玩法。這是首篇,一個整體的介紹,如果您有興趣可以去 fly官網(wǎng)了解更多。

簡介

Fly.js 是一個基于 promise 的,輕量且強大的 Javascript http 網(wǎng)絡(luò)庫,它有如下特點:

提供統(tǒng)一的 Promise API。

支持瀏覽器環(huán)境,輕量且非常輕量 。

支持 Node 環(huán)境。

支持請求/響應(yīng)攔截器。

自動轉(zhuǎn)換 JSON 數(shù)據(jù)。

支持切換底層 Http Engine,可輕松適配各種運行環(huán)境。

瀏覽器端支持全局Ajax攔截 。

H5頁面內(nèi)嵌到原生 APP 中時,支持將 http 請求轉(zhuǎn)發(fā)到 Native。支持直接請求圖片。

高度可定制、可拆卸、可拼裝。

定位與目標(biāo)

Fly 的定位是成為 Javascript http請求的終極解決方案。也就是說,在任何能夠執(zhí)行 Javascript 的環(huán)境,只要具有訪問網(wǎng)絡(luò)的能力,F(xiàn)ly都能運行在其上,提供統(tǒng)一的API。

與axios和Fetch對比

詳細的對比請參照flyio官網(wǎng)的文章 與axios和Fetch對比 。

安裝 使用NPM
npm install flyio
使用CDN
UMD
https://unpkg.com/flyio/dist/umd/fly.umd.min.js
例子

下面示例如無特殊說明,則在瀏覽器和node環(huán)境下都能執(zhí)行。

發(fā)起GET請求
var fly=require("flyio")
//通過用戶id獲取信息,參數(shù)直接寫在url中
fly.get("/user?id=133")
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });

//query參數(shù)通過對象傳遞
fly.get("/user", {
      id: 133
  })
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });
發(fā)起POST請求
fly.post("/user", {
    name: "Doris",
    age: 24
    phone:"18513222525"
  })
  .then(function (response) {
    console.log(response);
  })
  .catch(function (error) {
    console.log(error);
  });
發(fā)起多個并發(fā)請求
function getUserRecords() {
  return fly.get("/user/133/records");
}

function getUserProjects() {
  return fly.get("/user/133/projects");
}

fly.all([getUserRecords(), getUserProjects()])
  .then(fly.spread(function (records, projects) {
    //兩個請求都完成
  }))
  .catch(function(error){
    console.log(error)
  })
直接通過 request 接口發(fā)起請求
//直接調(diào)用request函數(shù)發(fā)起post請求
fly.request("/test",{hh:5},{
    method:"post",
    timeout:5000 //超時設(shè)置為5s
 })
.then(d=>{ console.log("request result:",d)})
.catch((e) => console.log("error", e))
發(fā)送URLSearchParams
const params = new URLSearchParams();
params.append("a", 1);
fly.post("",params)
.then(d=>{ console.log("request result:",d)})

注:Node環(huán)境不存在URLSearchParams。各個瀏覽器對URLSearchParams的支持程度也不同,使用時務(wù)必注意

發(fā)送 FormData
 var formData = new FormData();
 var log=console.log
 formData.append("username", "Chris");
 fly.post("../package.json",formData).then(log).catch(log)

注:Fly目前只在支持 FormData 的瀏覽器環(huán)境中支持 FormData,node環(huán)境下對 formData 的支持方式稍有不同,詳情戳這里 Node 下增強的API 。

請求二進制數(shù)據(jù)
fly.get("/Fly/v.png",null,{
    responseType:"arraybuffer"
}).then(d=>{
  //d.data 為ArrayBuffer實例
})

注:在瀏覽器中時 responseType 值可為 "arraybuffer" 或"blob"之一。在node下只需設(shè)為 "stream"即可。

攔截器

Fly支持請求/響應(yīng)攔截器,可以通過它在請求發(fā)起之前和收到響應(yīng)數(shù)據(jù)之后做一些預(yù)處理。

//添加請求攔截器
fly.interceptors.request.use((config,promise)=>{
    //給所有請求添加自定義header
    config.headers["X-Tag"]="flyio";
    //可以通過promise.reject/resolve直接中止請求
    //promise.resolve("fake data")
    return config;
})

//添加響應(yīng)攔截器,響應(yīng)攔截器會在then/catch處理之前執(zhí)行
fly.interceptors.response.use(
    (response,promise) => {
        //只將請求結(jié)果的data字段返回
        return response.data
    },
    (err,promise) => {
        //發(fā)生網(wǎng)絡(luò)錯誤后會走到這里
        //promise.resolve("ssss")
    }
)

如果你想移除攔截器,只需要將攔截器設(shè)為null即可:

fly.interceptors.request.use(null)
fly.interceptors.response.use(null,null)
Node

無論是在瀏覽器環(huán)境,還是在 Node 環(huán)境,F(xiàn)ly在上層提供了統(tǒng)一的 Promise API。這意味著無論您是 web 開發(fā)還是 node 開發(fā),您都可以以相同的調(diào)用方式來發(fā)起http請求。不過,由于node和瀏覽器環(huán)境本身的差異,在Node環(huán)境下,F(xiàn)ly除了支持基本的API之外,還提供了一些增強的API,這些 API 主要涉及文件下載、多文件上傳、http代理等眾多強大的功能,詳情請參考 Node 下增強的API

錯誤處理

請求失敗之后,catch 捕獲到的 err 為 Error 的一個實例,err有兩個字段:

{
  message:"Not Find 404", //錯誤消息
  status:404 //如果服務(wù)器可通,則為http請求狀態(tài)碼。網(wǎng)絡(luò)異常時為0,網(wǎng)絡(luò)超時為1
}
錯誤碼 含義
0 網(wǎng)絡(luò)錯誤
1 請求超時
2 文件下載成功,但保存失敗,此錯誤只出現(xiàn)node環(huán)境下
>=200 http請求狀態(tài)碼
請求配置選項

可配置選項:

{
  headers:{}, //http請求頭,
  baseURL:"", //請求基地址
  timeout:0,//超時時間,為0時則無超時限制
  withCredentials:false //跨域時是否發(fā)送cookie
}

配置支持實例級配置單次請求配置

實例級配置

實例級配置可用于當(dāng)前Fly實例發(fā)起的所有請求

//定義公共headers
fly.config.headers={xx:5,bb:6,dd:7}
//設(shè)置超時
fly.config.timeout=10000;
//設(shè)置請求基地址
fly.config.baseURL="https://wendux.github.io/"
單次請求配置

需要對單次請求配置時,需使用request方法,配置只對當(dāng)次請求有效。

fly.request("/test",{hh:5},{
    method:"post",
    timeout:5000 //超時設(shè)置為5s
})

注:若單次配置和實例配置沖突,則會優(yōu)先使用單次請求配置

API fly.get(url, data, options)

發(fā)起 get 請求,url請求地址,data為請求數(shù)據(jù),在瀏覽器環(huán)境下類型可以是:

String|Json|Object|Array|Blob|ArrayBuffer|FormData

options為請求配置項。

fly.post(url, data, options)

發(fā)起post請求,參數(shù)含義同fly.get。

fly.request(url, data, options)

發(fā)起請求,參數(shù)含義同上,在使用此API時需要指定options 的method:

//GET請求
fly.request("/user/8" null, {method:"get"})
//DELETE 請求
fly.request("/user/8/delete", null, {method:"delete"})
//PUT請求
fly.request("/user/register", {name:"doris"}, {method:"PUT"})
......

request 適合在 RESTful API 的場景下使用,為了方便使用,fly提供了快捷方法:

fly.put(url, data, options)
fly.delete(url,data,options)
fly.patch(url,data,options)
fly.all([])

發(fā)起多個并發(fā)請求,參數(shù)是一個promise 數(shù)組;當(dāng)所有請求都成功后才會調(diào)用then,只要有一個失敗,就會調(diào)catch。

創(chuàng)建Fly實例

為方便使用,在引入flyio庫之后,會創(chuàng)建一個默認實例,一般情況下大多數(shù)請求都是通過默認實例發(fā)出的,但在一些場景中需要多個實例(可能使用不同的配置請求),這時你可以手動new一個:

//npm、node環(huán)境下
var  Fly=require("flyio/dist/npm/fly") //注意!此時引入的是 "fio/dist/npm/fly"
var nFly=new Fly();

//CDN引入時直接new
var nFly=new Fly();
Http Engine

Fly 引入了Http Engine 的概念,所謂 Http Engine,就是真正發(fā)起 http 請求的引擎,這在瀏覽器中一般都是XMLHttpRequest,而在 Node 環(huán)境中,可以用任何能發(fā)起網(wǎng)絡(luò)請求的庫/模塊實現(xiàn)。Fly 可以自由更換底層 Http Engine 。事實上,F(xiàn)ly 正是通過更換 Http Engine 而實現(xiàn)同時支持瀏覽器環(huán)境和Node環(huán)境的 。不過,Http Engine 并不局限于Node 和 瀏覽器環(huán)境,也可以是 Android、ios、electron等,正是由于這些,F(xiàn)ly 才有了一個非常獨特而強大的功能——請求重定向?;谡埱笾囟ㄏ?,我們可以實現(xiàn)一些非常有用的功能,比如將內(nèi)嵌到 APP 的所有 http 請求重定向到 Native ,然后在端上( Android、ios )統(tǒng)一發(fā)起網(wǎng)絡(luò)請求、進行 cookie 管理、證書校驗等,詳情請戳 Fly Http Engine

全局Ajax攔截

在瀏覽器中,可以通過用 Fly engine 替換 XMLHttpRequest 的方式攔截全局的的 Ajax 請求,無論上層使用的是何種網(wǎng)絡(luò)庫。

體積

在瀏覽器環(huán)境下,一個庫的大小是非常重要的。這方面 Fly 做的很好,它在保持強大的功能的同時,將自己的身材控制到了最好。min 只有 4.6K 左右,GZIP 壓縮后不到 2K,體積是 axios 的四分之一。

Finally

如果感覺 Fly 對您有用,歡迎 star 。 github: https://github.com/wendux/fly

補充一句

招前端,招前端,招前端!最近有找工作或者想換工作的加我微信Demons-du哦。 職位地點:北京

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

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

相關(guān)文章

  • 支持所有JavaScript運行時的HTTP網(wǎng)絡(luò)庫-Fly.js

    摘要:已支持的平臺官方支持的運行時包括瀏覽器微信小程序。瀏覽器端支持全局攔截。支持請求配置頁面內(nèi)嵌到原生中時,支持將請求轉(zhuǎn)發(fā)到,支持直接請求圖片。 showImg(https://segmentfault.com/img/bV4pTj?w=482&h=157); Fly.js 的定位是成為 Javascript http請求的終極解決方案,也就是說,在任何能夠執(zhí)行 Javascript 的環(huán)...

    liaosilzu2007 評論0 收藏0
  • 在小程序/mpvue中使用flyio發(fā)起網(wǎng)絡(luò)請求

    摘要:上一篇文章介紹了在快應(yīng)用中使用,本文主要介紹一下如何在微信小程序中使用。下面我們看看在微信小程序中和中如何使用微信小程序微信小程序采用開發(fā)技術(shù)棧,使用語言開發(fā),但是運行時和瀏覽器又有所不同,導(dǎo)致等庫無法在微信小程序中使用,而可以。 Fly.js 一個基于Promise的、強大的、支持多種JavaScript運行時的http請求庫. 有了它,您可以使用一份http請求代碼在瀏覽器、微信...

    mumumu 評論0 收藏0
  • mpvue開發(fā)微信小程序,Fly.js 簡單使用

    摘要:小程序原生是小程序平臺特定,不能運用到導(dǎo)致小程序轉(zhuǎn)時,需要重寫網(wǎng)絡(luò)請求部分代碼。為了解決平臺差異,代碼復(fù)用,將平臺差異在底層屏蔽,支持切換底層,可輕松適配各種運行環(huán)境只是入口文件不同。 小程序原生wx.request是小程序平臺特定api ,不能運用到web導(dǎo)致mpvue小程序轉(zhuǎn)web時,需要重寫網(wǎng)絡(luò)請求部分代碼。為了解決平臺差異,代碼復(fù)用 ,fly.js將平臺差異在底層屏蔽,支持切換...

    xiaokai 評論0 收藏0
  • 一篇文章讓你學(xué)會如何選擇 JS HTTP 請求

    摘要:本文將帶你了解不同請求的原理,以及如何為項目選擇合適的請求庫。小程序年微信小程序上線,隨后各大平臺都推出自己的小程序。下面為目前較火的請求庫。支持微信小程序和瀏覽器是一個基于的請求庫,可以用在微信小程序和瀏覽器中,對上述平臺都做了兼容。 以前前端提到網(wǎng)絡(luò)請求通常是指瀏覽器,但現(xiàn)在隨著 Node.js、小程序的出現(xiàn),網(wǎng)絡(luò)請求不再局限于瀏覽器。本文將帶你了解不同請求的原理,以及如何為項目選...

    Render 評論0 收藏0

發(fā)表評論

0條評論

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