91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

高台县| 凤凰县| 南昌市| 曲周县| 崇文区| 昌黎县| 靖州| 平塘县| 嘉鱼县| 响水县| 平度市| 北京市| 开封县| 平顺县| 达孜县| 惠安县| 石泉县| 临汾市| 从化市| 张家界市| 布拖县| 忻州市| 延寿县| 昭平县| 永德县| 绵阳市| 广东省| 灌阳县| 湖南省| 武城县| 沈阳市| 隆化县| 吉木萨尔县| 乌拉特中旗| 宁蒗| 祁阳县| 阜城县| 玉屏| 辰溪县| 贺兰县| 濮阳市|