在小程序/mpvue中使用flyio發(fā)起網(wǎng)絡(luò)請求的方法
Fly.js 一個基于Promise的、強大的、支持多種JavaScript運行時的http請求庫. 有了它,您可以使用一份http請求代碼在瀏覽器、微信小程序、Weex、Node、React Native、快應(yīng)用中都能正常運行。同時可以方便配合主流前端框架 ,最大可能的實現(xiàn) Write Once Run Everywhere。
Flyio Github: https://github.com/wendux/fly
問題
隨著 Weex 、mpvue 的發(fā)布,他們都是支持Vue.js語法。目前vue已經(jīng)你能夠運行在瀏覽器、小程序和Native了。盡管各個平臺仍有差異,但已經(jīng)基本能實現(xiàn) Write Once Run Everywhere 。這使得我們可以在多個端上實現(xiàn)盡可能大限度在代碼復用。但是無論是 vue 還是Weex 、mpvue,它們本質(zhì)上都只是一個View層,也就說最好的情況,也只能實現(xiàn)UI復用。但對于一個應(yīng)用程序來說,除了UI,最重要的就是數(shù)據(jù)了,而數(shù)據(jù)來源一般都是來自網(wǎng)絡(luò)請求(大多數(shù)都是http)。在使用這些框架時,您的網(wǎng)絡(luò)請求,都需要使用平臺特定的API!這很糟糕,意味著您網(wǎng)絡(luò)請求的代碼不能復用,所以盡管UI可以復用,但我們還需要去適配網(wǎng)絡(luò)請求部分的代碼。
Flyio簡介
要上述問題,就需要一個能支持多個平臺網(wǎng)絡(luò)庫,用戶層提供統(tǒng)一的API,將平臺差異在底層屏蔽。而 Fly.js就是這醬紫的一個網(wǎng)絡(luò)庫,為了方便axios使用者遷移,fly.js API設(shè)計風格和axios相似(但不完全相同)!
Fly.js 通過在不同 JavaScript 運行時通過在底層切換不同的 Http Engine來實現(xiàn)多環(huán)境支持,但同時對用戶層提供統(tǒng)一、標準的Promise API。不僅如此,F(xiàn)ly.js還支持請求/響應(yīng)攔截器、自動轉(zhuǎn)化JSON、請求轉(zhuǎn)發(fā)等功能,詳情請參考:https://github.com/wendux/fly 。下面我們看看在微信小程序、mpvue中和中如何使用fly.
支持快應(yīng)用
快應(yīng)用是九大手機廠商基于硬件平臺共同推出的新型應(yīng)用生態(tài)。用戶無需下載安裝,即點即用,享受原生應(yīng)用的性能體驗。快應(yīng)用采用web開發(fā)技術(shù)棧,使用JavaScript語言開發(fā),flyio官方在第一時間支持了快應(yīng)用。具體使用參照下面文檔。
標準的API
Fly在上層提供了一套標準的API,這樣,您就可以在各個JavaScript環(huán)境中,以相同的方式發(fā)起網(wǎng)絡(luò)請求,不同平臺對應(yīng)一個平臺相關(guān)的adapter,將平臺差異在底層屏蔽,使用時不同平臺只需要引入flyio npm包中相應(yīng)平臺的入口文件即可,也正是因為如此,fly在各個平臺下都可以保證輕量(沒有冗余代碼)。
同時,為了方便axios使用者遷移,fly.js API設(shè)計風格和axios相似(但不完全相同)!
Fly.js 通過在不同 JavaScript 運行時通過在底層切換不同的 Http Engine來實現(xiàn)多環(huán)境支持,但同時對用戶層提供統(tǒng)一、標準的Promise API。不僅如此,F(xiàn)ly.js還支持請求/響應(yīng)攔截器、自動轉(zhuǎn)化JSON、請求轉(zhuǎn)發(fā)等功能,詳情請參考:
已支持的平臺
目前Fly.js支持的平臺包括:Node.js 、微信小程序 、Weex、React Native 、Quick App 和瀏覽器,這些平臺的 JavaScript 運行時都是不同的。更多的平臺正在持續(xù)添加中,請保持關(guān)注。
微信小程序
微信小程序采用web開發(fā)技術(shù)棧,使用JavaScript語言開發(fā),但是JavaScript運行時和瀏覽器又有所不同,導致axios、jQuery等庫無法在微信小程序中使用,而flyio可以。下面給出具體使用方法
引入fly
Flyio在各個平臺下的標準API是一致的,只是入口文件不同,在微信小程序中引入:
Npm安裝:npm install flyio --save.
var Fly=require("flyio/dist/npm/wx") var fly=new Fly
如果您的微信小程序項目沒有使用npm來管理依賴,您可以直接下載源碼到您的小程序工程,下載鏈接wx.js 或wx.umd.min.js 下載任意一個,保存到本地工程目錄,假設(shè)在“l(fā)ib”目錄,接下來引入:
var Fly=require("../lib/wx") //wx.js為您下載的源碼文件 var fly=new Fly; //創(chuàng)建fly實例
引入之后,您就可以對fly實例進行全局配置、添加攔截器、發(fā)起網(wǎng)絡(luò)請求了。
使用
Fly 基于Promise提供了Restful API,你可以方便的使用它們,具體請參考fly 文檔 。下面給出一個簡單的示例
//添加攔截器 fly.interceptors.request.use((config,promise)=>{ //給所有請求添加自定義header config.headers["X-Tag"]="flyio"; return config; }) //配置請求基地址 fly.config.baseURL='http://www.dtworkroom.com/doris/1/2.0.0/' ... Page({ //事件處理函數(shù) bindViewTap: function() { //發(fā)起get請求 fly.get("/test",{xx:6}).then((d)=>{ //輸出請求數(shù)據(jù) console.log(d.data) //輸出響應(yīng)頭 console.log(d.header) }).catch(err=>{ console.log(err.status,err.message) }) ... }) })
在mpvue中使用
在mpvue 中您也可以將fly實例掛在vue原型上,這樣就可以在任何組件中通過this方便的調(diào)用:
var Fly=require("flyio/dist/npm/wx") var fly=new Fly ... //添加全局配置、攔截器等 Vue.prototype.$http=fly //將fly實例掛在vue原型上
在組件中您可以方便的使用:
this.$http.get("/test",{xx:6}).then((d)=>{ //輸出請求數(shù)據(jù) console.log(d.data) //輸出響應(yīng)頭 console.log(d.header) }).catch(err=>{ console.log(err.status,err.message) })
反饋
如果您有問題歡迎在 在github 提issue . fly.js github: github.com/fly
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue v-for循環(huán)重復數(shù)據(jù)無法添加問題解決方法【加track-by=''索引''】
這篇文章主要介紹了vue v-for循環(huán)重復數(shù)據(jù)無法添加問題解決方法,結(jié)合實例形式分析了vue.js通過在v-for循環(huán)中添加track-by='索引'解決重復數(shù)據(jù)無法添加問題相關(guān)操作技巧,需要的朋友可以參考下2019-03-03詳解vue-cli與webpack結(jié)合如何處理靜態(tài)資源
本篇文章主要介紹了詳解vue-cli與webpack結(jié)合如何處理靜態(tài)資源,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09vue項目webpack中Npm傳遞參數(shù)配置不同域名接口
這篇文章主要介紹了vue項目webpack中Npm傳遞參數(shù)配置不同域名接口,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06Vue解決echart在element的tab切換時顯示不正確問題
這篇文章主要介紹了Vue解決echart在element的tab切換時顯示不正確問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08Vue axios與Go Frame后端框架的Options請求跨域問題詳解
這篇文章主要介紹了Vue axios與Go Frame后端框架的Options請求跨域問題詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-03-03詳解element上傳組件before-remove鉤子問題解決
這篇文章主要介紹了詳解element上傳組件before-remove鉤子問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04