欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2018年09月13日 10:37:11   作者:陳陳陳大神  
這篇文章主要介紹了mpvue中使用flyjs全局攔截的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

我們安裝好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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue中動態(tài)class的多種寫法

    Vue中動態(tài)class的多種寫法

    這篇文章主要介紹了Vue之動態(tài)class的幾種寫法,本文結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • VUE項目中加載已保存的筆記實例方法

    VUE項目中加載已保存的筆記實例方法

    在本篇文章里小編給大家整理了一篇關(guān)于VUE項目中加載已保存的筆記實例方法,有興趣的讀者們可以參考下。
    2019-09-09
  • vue數(shù)據(jù)字典取鍵值方式

    vue數(shù)據(jù)字典取鍵值方式

    這篇文章主要介紹了vue數(shù)據(jù)字典取鍵值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue父組件監(jiān)聽子組件生命周期

    Vue父組件監(jiān)聽子組件生命周期

    這篇文章主要介紹了Vue父組件監(jiān)聽子組件生命周期,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-09-09
  • vue中watch的實際開發(fā)學習筆記

    vue中watch的實際開發(fā)學習筆記

    watch是Vue實例的一個屬性是用來響應(yīng)數(shù)據(jù)的變化,需要在數(shù)據(jù)變化時執(zhí)行異步或開銷較大的操作時,這個方式是最有用的,下面這篇文章主要給大家介紹了關(guān)于vue中watch的實際開發(fā)筆記,需要的朋友可以參考下
    2022-11-11
  • Vue指令實現(xiàn)大屏元素分辨率適配詳解

    Vue指令實現(xiàn)大屏元素分辨率適配詳解

    這篇文章主要為大家介紹了Vue指令實現(xiàn)大屏元素分辨率適配詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue監(jiān)聽鍵盤事件的快捷方法【推薦】

    vue監(jiān)聽鍵盤事件的快捷方法【推薦】

    這篇文章主要介紹了vue監(jiān)聽鍵盤事件的快捷方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-07-07
  • 在 Vue 項目中引入 tinymce 富文本編輯器的完整代碼

    在 Vue 項目中引入 tinymce 富文本編輯器的完整代碼

    這篇文章主要介紹了在 Vue 項目中引入 tinymce 富文本編輯器的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • Vue中使用js-cookie詳情

    Vue中使用js-cookie詳情

    這篇文章主要介紹了Vue中使用js-cookie詳情,文章圍繞js-cookie的相關(guān)資料展開詳細內(nèi)容具有一定的的參考價值,需要的小伙伴可以參考一下
    2022-03-03
  • Vue3如何理解ref toRef和toRefs的區(qū)別

    Vue3如何理解ref toRef和toRefs的區(qū)別

    本文主要介紹了Vue3如何理解ref toRef和toRefs的區(qū)別,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12

最新評論