Heim > Web-Frontend > js-Tutorial > Einführung in die Kapselung von Axios-Anfragen in Vue (Code)

Einführung in die Kapselung von Axios-Anfragen in Vue (Code)

不言
Freigeben: 2019-03-23 16:15:04
nach vorne
2947 Leute haben es durchsucht

Dieser Artikel bietet Ihnen eine Einführung (Code) zur Kapselung von Axios-Anfragen in Vue. Ich hoffe, dass er für Freunde hilfreich ist.

1. Anfragemodulverzeichnis senden

Einführung in die Kapselung von Axios-Anfragen in Vue (Code)

2. /api/url speichert die URL jedes Moduls

// 商品模块 product.js
const product = {
  sku: {
    list: '/product/product/speclist',
    options: '/product/product/options'
  }
}
export default product

// 公用请求模块 common.js
const common = {
  region: {
    provinces: '/region/region/list',
    cities: '/region/region/list'
  },
  upload: {
    image: '/product/product/upload'
  }
}
export default common
Nach dem Login kopieren

Senden Bei Anfrage, Sie müssen nur den Schlüssel (sku/list) angeben, wie zum Beispiel: this.$ajax('sku/list', param); vorausgesetzt, dass die von axios festgelegte Basis-URL http://prod.storm.com/api/ ist. , dann am Ende Anforderungsadresse: http://prod.storm.com/api/pro...

3.requireURLs.js

Verwenden Sie den vom Webpack bereitgestellten require.context, um src/api/url Alle Dateien mit dem Suffix js importieren und ein Objekt aussortieren.

let urls = {}
const req = require.context('./url', false, /\.js$/)

const requireAll = requireContext => requireContext.keys().map(i => {
  let url = requireContext(i)
  Object.assign(urls, url.default)
})
requireAll(req)
export default urls
Nach dem Login kopieren

Integrieren Sie common.js und product.js, und das endgültige Objekt lautet wie folgt:

urls = {
  sku: {
    list: '/product/product/speclist',
    options: '/product/product/options'
  },
  region: {
    provinces: '/region/region/list',
    cities: '/region/region/list'
  },
  upload: {
    image: '/product/product/upload'
  }
}
Nach dem Login kopieren

4.ajax.js

import axios from 'axios'
import qs from 'qs'
import jsd from 'js-file-download'
import store from '@/store'
import urlObj from './requireURLs'
import { Message, MessageBox } from 'element-ui'
import { getToken } from '@/utils/auth'

const service = axios.create({
  baseURL: `${process.env.BASE_API}/api/`, // 不同环境(dev/prod/test)使用不同的baseURL
  timeout: 5000
})
service.interceptors.request.use(
  config => {
    // 上传文件时,config.data的数据类型是FormData,
    // qs.stringify(FormData)的结果是空字符串,导致报出上传文件为空的错误
    if (config.method === 'post' && config.data.constructor !== FormData) {
      config.data = qs.stringify(config.data)
    }
    if (store.getters.token) {
      config.headers.common['Auth-Token'] = getToken()
      // Auth-Token 登录过期后,重新登录不传token
      if (!config.headers.common['Auth-Token']) {
        delete config.headers.common['Auth-Token']
      }
    }
    return config
  },
  error => {
    Promise.reject(error)
  }
)
service.interceptors.response.use(
  response => {
    const res = response.data
    if (response.headers['content-type'].indexOf('application/vnd.ms-excel') !== -1) {
      let fileName = response.headers['content-disposition'].split('=')[1]
      jsd(res, fileName)
      return
    }
    if (res.code === 0) { // 和后台约定code:0代表请求成功
      return res
    } else {
      if (res.code === 18500) { // 和后台约定code:18500代表token未过期,但是被更新了
        handleLogin('您已被登出,请重新登录')
      } else if (res.code === 18501) { // 和后台约定code:18500代表token过期
        handleLogin('登录已失效,请重新登录')
      } else {
        // 统一处理接口的报错信息,如果需要具体到页面去处理,可以和后台另外约定一个code
        Message({
          message: res.msg,
          type: 'error',
          duration: 3 * 1000
        })
      }
      return Promise.reject(res)
    }
  },
  error => {
    console.log('err ' + error)
    let data = error.response.data
    Message({
      message: data.msg,
      type: 'error',
      duration: 3 * 1000
    })
    return Promise.reject(data)
  }
)

const handleLogin = title => {
  MessageBox.confirm(title, '提示', {
    confirmButtonText: '重新登录',
    showCancelButton: false,
    showClose: false,
    type: 'warning'
  }).then(() => {
    store.dispatch('FedLogout').then(() => {
      location.reload()
    })
  })
}

const ajax = (path, data = {}, options = {}) => {
  let url = path.indexOf('http') === -1 ? path.split('/').reduce((o, k) => {
    return o[k]
  }, urlObj) : path
  let method = options.method || 'post'
  let params = { url, method }

  if (options.method === 'get') {
    Object.assign(params, { params: data }, options)
  } else {
    Object.assign(params, { data }, options)
  }
  return service(params)
}

export default ajax
Nach dem Login kopieren

5. Erstellen Sie eines in src/ Plugins ajaxPlugin.js und Referenz

// ajaxPlugin.js
import ajax from '@/api/ajax'

let ajaxPlugin = {}

ajaxPlugin.install = Vue => {
  Vue.prototype.$ajax = ajax
}

export default ajaxPlugin

// main.js
import ajaxPlugin from '@/plugins/ajaxPlugin'

Vue.use(ajaxPlugin)
Nach dem Login kopieren

in src/main.js 6. Senden Sie eine Anfrage:

this.$ajax('sku/list').then(res => {})
Nach dem Login kopieren

Dieser Artikel ist hier überall, Sie können auf weitere spannende PHP-Inhalte achten Kolumne JavaScript-Video-Tutorial der chinesischen Website!


Das obige ist der detaillierte Inhalt vonEinführung in die Kapselung von Axios-Anfragen in Vue (Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:segmentfault.com
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage