溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mpvue中使用flyjs全局攔截的實現(xiàn)代碼

發(fā)布時間:2020-10-04 02:39:39 來源:腳本之家 閱讀:160 作者:陳陳陳大神 欄目:web開發(fā)

我們安裝好flyio之后

npm install flyio

找到src目錄下的main.js文件

首先引入flyjs并實例化

var Fly=require("flyio/dist/npm/wx")
var fly=new Fly

比方說我們每次請求我們自己的服務(wù)器接口的時候需要帶上appID,用戶登陸后需要帶上openId

// 請求攔截
fly.interceptors.request.use((request)=>{
 
 request.body.appId = 'xxx'
  // 用戶的openId在獲取之后添加到全局變量中如果存在,我們將它添加到請求參數(shù)里面
 let openId = Vue.prototype.globalData.openId;
 if(openId){
  request.body.openId = openId
 }
})

當服務(wù)器發(fā)生錯誤,或者用戶網(wǎng)絡(luò)錯誤導(dǎo)致請求失敗的時候,我們可以添加一個響應(yīng)攔截

// 響應(yīng)攔截
fly.interceptors.response.use(
 (response) => {
 
 
 },
 (err) => {
  //發(fā)生網(wǎng)絡(luò)錯誤后會走到這里
  //return Promise.resolve("ssss")
  wx.hideLoading();
  wx.showToast({
   title:'網(wǎng)絡(luò)不流暢,請稍后再試!',
   icon:'none',
  });
 
 })

最后將flyjs掛載到vue的原型上

// 將fly掛載在Vue的原型上
Vue.prototype.$flyio = fly

不同頁面直接使用this.$flyio請求(是不是很方便)

示例:

fly里面的攔截機制還是很強大的,并且在錯誤返回信息做了優(yōu)化處理,在fly攔截器中支持執(zhí)行異步任務(wù),就是說在請求數(shù)據(jù)的時候如果攔截到token不存在那么我們就可以在攔截器中重新獲取token,再接著執(zhí)行之前的請求。

const Fly = require("flyio/dist/npm/wx")
const fly = new Fly
Vue.prototype.$http = fly;
 
fly.interceptors.request.use((request) => {
 //給所有請求添加自定義header
 if (api.Get('token')) {
  request.timeout = 30000,
   request.headers = {
    "content-type": "application/json",
    "cld.stats.page_entry": api.Get('scene'),
    "version": store.state.version,
    "token": api.Get('token')
   }
  wx.showLoading({
   title: "加載中",
   mask: true,
  });
  return request;
 } else {
  fly.lock();//鎖住請求
  return Public.Load().then(res => {
   request.timeout = 30000,
    request.headers = {
     "content-type": "application/json",
     "cld.stats.page_entry": api.Get('scene'),
     "version": store.state.version,
     "token": api.Get('token')
    }
   wx.showLoading({
    title: "加載中",
    mask: true,
   });
    //等待token返回之后在解鎖,
   fly.unlock();
   return request;//繼續(xù)之前的請求,
  })
 }
})
 
fly.interceptors.response.use(
 (response) => {
  wx.hideLoading();
  return response
 },
 (err) => {
  wx.hideLoading();
  if (err.status == 0) {
   return "網(wǎng)絡(luò)連接異常"
  } else if (err.status == 1) {
   return "網(wǎng)絡(luò)連接超時"
  } else if (err.status == 401) {
   return "用戶未登錄"
  } else {
   if (err.response.data.message) {
    return err.response.data.message
   } else {
    return '請求數(shù)據(jù)失敗,請稍后再試'
   }
  };
  // Do something with response error
 }
)

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI