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

Vue接口封裝的完整步驟記錄

 更新時(shí)間:2021年05月14日 11:18:07   作者:火腿腸燒烤大賽冠軍  
對(duì)于中小型企業(yè),vue應(yīng)用越來(lái)越多,學(xué)習(xí)vue相對(duì)于react的成本要低點(diǎn),入門相對(duì)簡(jiǎn)單。這篇文章主要給大家介紹了關(guān)于Vue接口封裝的相關(guān)資料,需要的朋友可以參考下

首先根據(jù)接口寫好對(duì)應(yīng)頁(yè)面的請(qǐng)求

內(nèi)容如圖盡量保證js文件名稱與頁(yè)面文件名稱相同(易于查找)

根據(jù)文件目錄動(dòng)態(tài)引入/導(dǎo)出接口

提高便捷性

/**
 * 自動(dòng)引入當(dāng)前文件夾下所有module
 * require.context(directory, useSubdirectories = false, regExp = /^.//);
 * @param {String} directory 讀取文件的路徑
 * @param {Boolean} directory 匹配文件的正則表達(dá)式
 * @param {regExp} regExp 讀取文件的路徑
 */
 const modulesFiles = require.context(
    './', // 在當(dāng)前目錄下查找
    false, // 不遍歷子文件夾
    /\.js$/ // 正則匹配 以 .js結(jié)尾的文件
)
 const modules = modulesFiles.keys().reduce((modules, modulePath) => {
   const moduleName = modulePath.replace(/^.\/(.*)\.js/,'$1')
   const value = modulesFiles(modulePath)
   modules[moduleName] = value.default
   return modules
   }, {})

export default modules

根據(jù)項(xiàng)目情況編寫攔截/插入內(nèi)容

import axios from 'axios'
import { MessageBox, Message } from 'element-ui'
import store from '@/store'
import { getToken } from '@/utils/auth'

// create an axios instance
const service = axios.create({
  baseURL: process.env.VUE_APP_BASE_API, // url = base url + request url
  // withCredentials: true, // send cookies when cross-domain requests
  timeout: 5000 // request timeout
})

// request interceptor
service.interceptors.request.use(
  config => {
    // 在發(fā)送請(qǐng)求之前做些什么

    if (store.getters.token) {
      // let each request carry token讓每個(gè)請(qǐng)求攜帶令牌
      // ['X-Token'] is a custom headers key 是一個(gè)自定義標(biāo)題鍵
      // please modify it according to the actual situation請(qǐng)根據(jù)實(shí)際情況修改
      config.headers['X-Token'] = getToken()
    }
    return config
  },
  error => {
    // do something with request error
    console.log(error) // for debug
    return Promise.reject(error)
  }
)

// response interceptor
service.interceptors.response.use(
  /**
   * If you want to get http information such as headers or status如果您想獲取http信息,如標(biāo)頭或狀態(tài)
   * Please return  response => response
  */

  /**
   * Determine the request status by custom code通過(guò)自定義代碼確定請(qǐng)求狀態(tài)
   * Here is just an example這里只是一個(gè)例子
   * You can also judge the status by HTTP Status Code您還可以通過(guò)HTTP狀態(tài)碼來(lái)判斷狀態(tài)
   */
  response => {
    const res = response.data
    // console.log(res);
    // 如果自定義代碼不是20000,則判斷為錯(cuò)誤.
    if (res.code !== 200) {
      Message({
        message: res.message || 'Error',
        type: 'error',
        duration: 5 * 1000
      })
      
      // 50008: 非法token; 50012: 其他客戶端已登錄; 50014: Token 已過(guò)期;
      if (res.code === 50008 || res.code === 50012 || res.code === 50014) {
        // to re-login
        MessageBox.confirm('您已注銷,可以取消以停留在此頁(yè)面,或重新登錄', '確認(rèn)注銷', {
          confirmButtonText: 'Re-Login',
          cancelButtonText: 'Cancel',
          type: 'warning'
        }).then(() => {
          store.dispatch('user/resetToken').then(() => {
            location.reload()
          })
        })
      }
      return Promise.reject(new Error(res.message || 'Error'))
    } else {
      return res
    }
  },
  error => {
    console.log('err' + error) // for debug
    Message({
      message: error.message,
      type: 'error',
      duration: 5 * 1000
    })
    return Promise.reject(error)
  }
)

export default service

編寫env文件

# just a flag
ENV = 'development'

# base api
VUE_APP_BASE_API = 'http://192.168.2.44:5001/v1'

vue繼承api

import serve from './api/index'
Vue.prototype.$api = serve;

使用

getAssetsList() {
  this.$api.assets
    .getAssetsList(this.queryInfo.num, this.queryInfo.size)
    .then((res) => {
      this.assetsList = res.data.cards
      this.total = res.data.page.totalCount
    })
    .catch(() => {
      this.$message.error({
        message: "失敗",
        duration: 700,
      })
    })
},

總結(jié)

到此這篇關(guān)于Vue接口封裝的文章就介紹到這了,更多相關(guān)Vue接口封裝內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue mvvm數(shù)據(jù)響應(yīng)實(shí)現(xiàn)

    vue mvvm數(shù)據(jù)響應(yīng)實(shí)現(xiàn)

    這篇文章主要介紹了vue mvvm數(shù)據(jù)響應(yīng)實(shí)現(xiàn)的方法,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-11-11
  • vue3+elementplus前端生成圖片驗(yàn)證碼完整代碼舉例

    vue3+elementplus前端生成圖片驗(yàn)證碼完整代碼舉例

    在開發(fā)過(guò)程中有時(shí)候需要使用圖片驗(yàn)證碼進(jìn)行增加安全強(qiáng)度,在點(diǎn)擊圖片時(shí)更新新的圖片驗(yàn)證碼,記錄此功能,以便后期使用,這篇文章主要給大家介紹了關(guān)于vue3+elementplus前端生成圖片驗(yàn)證碼的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • Vue3之狀態(tài)管理器(Pinia)詳解及使用方式

    Vue3之狀態(tài)管理器(Pinia)詳解及使用方式

    這篇文章主要介紹了Vue3之狀態(tài)管理器(Pinia)詳解及使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • elementUI樣式修改未生效問(wèn)題詳解(掛載到了body標(biāo)簽上)

    elementUI樣式修改未生效問(wèn)題詳解(掛載到了body標(biāo)簽上)

    vue+elementUI項(xiàng)目開發(fā)中,經(jīng)常遇到修改elementUI組件樣式無(wú)效的問(wèn)題,這篇文章主要給大家介紹了關(guān)于elementUI樣式修改未生效問(wèn)題的相關(guān)資料,掛載到了body標(biāo)簽上,需要的朋友可以參考下
    2023-04-04
  • 淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法

    淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法

    下面小編就為大家分享一篇淺談Vue-cli單文件組件引入less,sass,css樣式的不同方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue實(shí)現(xiàn)搜索小功能

    vue實(shí)現(xiàn)搜索小功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)搜索小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • el-table實(shí)現(xiàn)給每行添加loading效果案例

    el-table實(shí)現(xiàn)給每行添加loading效果案例

    這篇文章主要介紹了el-table實(shí)現(xiàn)給每行添加loading效果案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • element-plus/element-ui走馬燈配置圖片及圖片自適應(yīng)的最簡(jiǎn)便方法

    element-plus/element-ui走馬燈配置圖片及圖片自適應(yīng)的最簡(jiǎn)便方法

    走馬燈功能在展示圖片時(shí)經(jīng)常用到,下面這篇文章主要給大家介紹了關(guān)于element-plus/element-ui走馬燈配置圖片及圖片自適應(yīng)的最簡(jiǎn)便方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • vue如何根據(jù)不同的環(huán)境使用不同的接口地址

    vue如何根據(jù)不同的環(huán)境使用不同的接口地址

    這篇文章主要介紹了vue如何根據(jù)不同的環(huán)境使用不同的接口地址問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 詳解element-ui日期時(shí)間選擇器的日期格式化問(wèn)題

    詳解element-ui日期時(shí)間選擇器的日期格式化問(wèn)題

    這篇文章主要介紹了詳解element-ui日期時(shí)間選擇器的日期格式化問(wèn)題,本文用到了DateTimePicker來(lái)選擇日期時(shí)間,但是在將數(shù)據(jù)傳回后臺(tái)的過(guò)程中遇到了一些令人頭疼的問(wèn)題,有興趣的一起來(lái)了解一下
    2019-04-04

最新評(píng)論