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

vue項目使用axios封裝request請求的過程

 更新時間:2023年04月21日 09:27:05   作者:藍胖子的多啦A夢  
這篇文章主要介紹了vue項目使用axios封裝request請求,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

一、封裝axios

1.src 目錄中新建utils文件夾
2.utils文件中建立request.js文件

request.js文件的內容
<1> 導入axios
<2> 我們可以聲明一個新的常量axios 我們可以配置一些基礎 公共的路徑配置 比如說baseURL timeout請求失敗超時報錯 withcookies…之類的東西

<3> 設置請求攔截
新的常量axios service.攔截器.請求.使用===》 里頭有兩個參數 一個成功的回調函數 一個失敗的回調函數
<4> 設置響應攔截
<5> 導出 導出這個模塊

完整代碼:

import axios from 'axios'
import { Notification } from 'element-ui'
// 創(chuàng)建axios實例
const service = axios.create({
    // baseURL: 'http://192.168.1.69:5000',
    baseURL: process.env.API_ROOT,
    timeout: 80000, // 請求超時時間
     withCredentials: true,
    // crossDomain: true
})

// request攔截器
service.interceptors.request.use(
    config => {
        if (getToken()) {
             config.headers['Authorization'] = getToken() // 讓每個請求攜帶自定義token 請根據實際情況自行修改
         }
        var lang = localStorage.getItem('lang')//因為項目中使用到了i18n國際化語言配置,請根據實際情況自行修改
        if (!lang) {
            lang = 'zh_CN'
        }
        config.headers['Accept-Language'] = lang.replace(/_/g, '-')
        config.headers['Content-Type'] = 'application/json'
        return config
    },
    error => {
        Promise.reject(error)
    }
)

// response 攔截器
service.interceptors.response.use(
    response => {
        return response.data
    },
    error => {
        // 兼容blob下載出錯json提示
        if (error.response.data instanceof Blob && error.response.data.type.toLowerCase().indexOf('json') !== -1) {
            const reader = new FileReader()
            reader.readAsText(error.response.data, 'utf-8')
            reader.onload = function (e) {
                const errorMsg = JSON.parse(reader.result).message
                Notification.error({
                    title: errorMsg,
                    duration: 5000
                })
            }
        } else {
            let code = 0
            try {
                code = error.response.data.status
            } catch (e) {
                if (error.toString().indexOf('Error: timeout') !== -1) {
                    Notification.error({
                        title: '網絡請求超時',
                        duration: 5000
                    })
                    return Promise.reject(error)
                }
            }

            if (code) {
                 if (code === 401) {
                     store.dispatch('LogOut').then(() => {
                         // 用戶登錄界面提示
                         Cookies.set('point', 401)
                         location.reload()
                    })
                 } else if (code === 403) {
                     router.push({ path: '/401' })
                 } else {
                const errorMsg = error.response.data.message
                if (errorMsg !== undefined) {
                    Notification.error({
                        title: errorMsg,
                        duration: 0
                    })
                }
              }
            } else {
                Notification.error({
                    title: '接口請求失敗',
                    duration: 5000
                })
            }
        }
        return Promise.reject(error)
    }
)
export default service

二、封裝api 函數

1.先導入封裝好的新的axios
2.然后我們可以封裝一些接口函數 比如說 登錄的 注冊的 首頁的 分類的 輪播的 //但是要確認參數傳的是get還是post請求

tips://比如說以后我們要維護封裝好的接口 這樣封裝好后我們就不需要去組件里一個一個去找,直接來這個文件修改即可
//組件化開模塊化發(fā)或者開發(fā) 它們都有一個原則
//高聚合 低耦合
//高聚合就是 一個組件的業(yè)務一定要聚合在一起 一個組件的業(yè)務越集中越好
//低耦合就是 組件和組件之間的耦合度一定要低 意思就是兩個組件之間的牽連越少越好

三、頁面中使用

<script>標簽中引入
import {
  getSetbrate,randomtest,autocalibrate,lightCheck,writeserial} from "@/api/mAdmin";

方法中調用

   // 設置閾值 獲取閾值
  onManualSend() {
      let data = {
        command: this.command,
      };
      writeserial(data).then((res) => {
        this.manualText = res.msg;
      });
    },

到此這篇關于vue項目 使用axios封裝request請求的文章就介紹到這了,更多相關vue axios封裝request請求內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue+ElementUi實現點擊表格中鏈接進行頁面跳轉與路由詳解

    Vue+ElementUi實現點擊表格中鏈接進行頁面跳轉與路由詳解

    在vue中進行前端網頁開發(fā)時,通常列表數據用el-table展示,下面這篇文章主要給大家介紹了關于Vue+ElementUi實現點擊表格中鏈接進行頁面跳轉與路由的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • Vue運用transition實現過渡動畫

    Vue運用transition實現過渡動畫

    vue的過渡動畫,主要是transition標簽的使用,配合css動畫實現的。接下來通過本文給大家分享Vue運用transition實現過渡動畫效果,感興趣的朋友一起看看吧
    2019-05-05
  • vue中返回結果是promise的處理方式

    vue中返回結果是promise的處理方式

    這篇文章主要介紹了vue中返回結果是promise的處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue基礎之事件簡寫、事件對象、冒泡、默認行為、鍵盤事件實例分析

    vue基礎之事件簡寫、事件對象、冒泡、默認行為、鍵盤事件實例分析

    這篇文章主要介紹了vue基礎之事件簡寫、事件對象、冒泡、默認行為、鍵盤事件,結合實例形式分析了vue.js事件簡寫、冒泡及阻止冒泡等相關操作技巧,需要的朋友可以參考下
    2019-03-03
  • vue3中獲取dom元素和操作實現方法

    vue3中獲取dom元素和操作實現方法

    ref是Vue3中一個非常重要的功能,它可以用來獲取DOM節(jié)點,從而實現對DOM節(jié)點的操作,下面這篇文章主要給大家介紹了關于vue3中獲取dom元素和操作實現的相關資料,需要的朋友可以參考下
    2023-06-06
  • 詳解在Vue中有條件地使用CSS類

    詳解在Vue中有條件地使用CSS類

    本篇文章主要介紹了詳解在Vue中有條件地使用CSS類,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • vue中@click如何綁定多個事件

    vue中@click如何綁定多個事件

    這篇文章主要介紹了vue中@click如何綁定多個事件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • 詳解vuex的簡單使用

    詳解vuex的簡單使用

    這篇文章主要介紹了詳解vuex的簡單使用,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • vue debug 二種方法

    vue debug 二種方法

    這篇文章主要介紹了vue debug 二種方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-09-09
  • vscode中vue代碼提示與補全沒反應解決(vetur問題)

    vscode中vue代碼提示與補全沒反應解決(vetur問題)

    這篇文章主要給大家介紹了關于vscode中vue代碼提示與補全沒反應解決(vetur問題)的相關資料,文中通過圖文將解決的方法介紹的非常詳細,需要的朋友可以參考下
    2023-03-03

最新評論