中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

mpvue中使用flyjs全局攔截的實現代碼

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

我們安裝好flyio之后

npm install flyio

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

首先引入flyjs并實例化

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

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

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

當服務器發生錯誤,或者用戶網絡錯誤導致請求失敗的時候,我們可以添加一個響應攔截

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

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

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

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

示例:

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

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;//繼續之前的請求,
  })
 }
})
 
fly.interceptors.response.use(
 (response) => {
  wx.hideLoading();
  return response
 },
 (err) => {
  wx.hideLoading();
  if (err.status == 0) {
   return "網絡連接異常"
  } else if (err.status == 1) {
   return "網絡連接超時"
  } else if (err.status == 401) {
   return "用戶未登錄"
  } else {
   if (err.response.data.message) {
    return err.response.data.message
   } else {
    return '請求數據失敗,請稍后再試'
   }
  };
  // Do something with response error
 }
)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

静安区| 锡林郭勒盟| 丰城市| 鄂托克旗| 桐庐县| 宁河县| 山阳县| 小金县| 桂林市| 建平县| 镇康县| 邢台县| 德阳市| 武山县| 绥芬河市| 柳州市| 股票| 松原市| 瑞金市| 内江市| 凤翔县| 乐都县| 离岛区| 皋兰县| 阿荣旗| 江阴市| 无极县| 吉木乃县| 宜良县| 绥阳县| 吴川市| 青冈县| 琼中| 平乐县| 延津县| 融水| 辽宁省| 平罗县| 新巴尔虎右旗| 临漳县| 潢川县|