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

封裝一下vue中的axios示例代碼詳解

 更新時間:2020年02月16日 10:09:06   作者:表示不會  
這篇文章主要介紹了封裝一下vue中的axios,本文通過示例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

在vue項目中,和后臺交互獲取數(shù)據(jù)這塊,我們通常使用的是axios庫,它是基于promise的http庫,可運行在瀏覽器端和node.js中。他有很多優(yōu)秀的特性,例如攔截請求和響應、取消請求、轉(zhuǎn)換json、客戶端防御cSRF等。所以我們的尤大大也是果斷放棄了對其官方庫vue-resource的維護,直接推薦我們使用axios庫。如果還對axios不了解的,可以移步axios文檔。

安裝

npm install axios; // 安裝axios

好了,下面開始今天的正文。

此次封裝用以解決: (對于登錄功能的可以直接使用,其他網(wǎng)絡請求也可以直接用,如果有潔癖,可以把token有關的幾行代碼刪掉)

ps:使用時得的引入axios時: import axios from '這個文件的名字及相對路徑'

  • 接受后臺token
  • post參數(shù)自動轉(zhuǎn)換,省略qs.stringify()
  • 后臺token過期之后自動清除本地數(shù)據(jù),以便下次再次輸入賬號密碼
  • 更好的錯誤提示信息
/**
 * 封裝網(wǎng)絡請求
 */
import axios from "axios"
import qs from "querystring"
import store from '../store'
import router from '../router'
//token過期之后重新回登錄界面
const toLogin = () =>{
 router.push("/login")
}
// 錯誤信息響應方法
const errroHandle = (status,other) => {
 switch(status){
  case 400:
   console.log("服務器無法理解請求信息");
   break;
  case 401:
   console.log("用戶信息驗證失敗");
   localStorage.removeItem("token"); // 可選項
   toLogin();
   break;
  case 403:
   console.log("請求被限制");
   localStorage.removeItem("token"); // 可選項
   toLogin();
   break;
  case 404:
   console.log("客戶端請求信息錯誤");
   break;
  default:
   console.log(other);
   break;
 }
}
// 創(chuàng)建axios對象
const instance = axios.create({
 timeout:5000
})
// 掛在全局對象
instance.defaults.baseUrl = "";
instance.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
// 攔截器:請求攔截和響應攔截 post請求參數(shù)需要轉(zhuǎn)碼
// axios的返回值對象要求是一個promise對象
instance.interceptors.request.use(config =>{
 if(config.method === "post"){
  config.data = qs.stringify(config.data)
 }
 if(store.state.token){
  config.headers.authorization = store.state.token;
 }
 return config;
},error => Promise.reject(error))
instance.interceptors.response.use(
 // 成功
 response => response.status === 200 ? Promise.resolve(response) :Promise.reject(response),
 // 失敗
 error => {
  const { response } = error;
  if(response){
   errroHandle(response.status,response.data)
   return Promise.reject(response)
  }else{
   // 錯誤信息都無法返回
   console.log("請求被中斷");
  }
 }
)
export default instance

總結(jié)

以上所述是小編給大家介紹的封裝一下vue中的axios示例代碼詳解,希望對大家有所幫助!

相關文章

  • vue實現(xiàn)自定義樹形組件的示例代碼

    vue實現(xiàn)自定義樹形組件的示例代碼

    這篇文章主要介紹了vue實現(xiàn)自定義樹形組件的示例代碼,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • 實例詳解vue中的代理proxy

    實例詳解vue中的代理proxy

    這篇文章主要介紹了vue中的代理proxy,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-02-02
  • vue中4個自定義指令講解及實例用法

    vue中4個自定義指令講解及實例用法

    在本篇文章里小編給大家整理了一篇關于vue中4個自定義指令講解及實例用法,有興趣的朋友們可以跟著學習下。
    2021-12-12
  • vue2.x element-ui實現(xiàn)pc端購物車頁面demo

    vue2.x element-ui實現(xiàn)pc端購物車頁面demo

    這篇文章主要為大家介紹了vue2.x element-ui實現(xiàn)pc端購物車頁面demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • vue展示dicom文件醫(yī)療系統(tǒng)的實現(xiàn)代碼

    vue展示dicom文件醫(yī)療系統(tǒng)的實現(xiàn)代碼

    這篇文章主要介紹了vue展示dicom文件醫(yī)療系統(tǒng)的實現(xiàn)代碼,非常不錯,具有一定的參考借鑒加載,需要的朋友可以參考下
    2018-08-08
  • Vue實現(xiàn)上下層疊輪播圖

    Vue實現(xiàn)上下層疊輪播圖

    這篇文章主要介紹了Vue實現(xiàn)上下層疊輪播圖,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue微信分享出來的鏈接點開是首頁問題的解決方法

    vue微信分享出來的鏈接點開是首頁問題的解決方法

    這篇文章主要為大家詳細介紹了vue微信分享出來的鏈接點開是首頁問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 純JS如何實現(xiàn)vue.js下的雙向綁定功能

    純JS如何實現(xiàn)vue.js下的雙向綁定功能

    對于vue下的雙向綁定功能,個人理解為在處理邏輯的過程中緩存了大量的node對象,node對象可以是html標簽、文本內(nèi)容。既然選擇了緩存這些對象,那么在用的過程中哪里需要改變就把node拿出來,進行標簽屬性的變更或者文本內(nèi)容的修改。本文主要講了如何實現(xiàn)雙向綁定
    2021-06-06
  • Vue封裝localStorage設置過期時間的示例詳解

    Vue封裝localStorage設置過期時間的示例詳解

    這篇文章主要介紹了Vue封裝localStorage設置過期時間的相關資料,在這個示例中,我們在MyComponent.vue組件的setup函數(shù)中導入了setItemWithExpiry和getItemWithExpiry函數(shù),并在函數(shù)內(nèi)部使用它們來設置和獲取帶有過期時間的localStorage數(shù)據(jù),需要的朋友可以參考下
    2024-06-06
  • Vue官方文檔梳理之全局配置

    Vue官方文檔梳理之全局配置

    這篇文章主要介紹了Vue官方文檔梳理之全局配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11

最新評論