>웹 프론트엔드 >JS 튜토리얼 >vue(코드)에서 axios 요청 캡슐화 소개

vue(코드)에서 axios 요청 캡슐화 소개

不言
不言앞으로
2019-03-23 16:15:042922검색

이 글은 Vue에서 axios 요청을 캡슐화하는 방법에 대한 소개(코드)를 제공합니다. 필요한 친구들이 참고할 수 있기를 바랍니다.

1. 요청 모듈 디렉터리 보내기

vue(코드)에서 axios 요청 캡슐화 소개

2. /api/url은 각 모듈의 URL을 저장합니다

// 商品模块 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

요청을 보낼 때 다음과 같은 키(sku/list)만 지정하면 됩니다. .$ ajax('sku/list', param); axios가 설정한 baseURL이 http://prod.storm.com/api/라고 가정하면 최종 요청 주소는 http://prod.storm.com입니다. /api/pro...

3.requireURLs.js

webpack에서 제공하는 require.context를 사용하여 src/api/url 아래에 접미사 js가 있는 모든 파일을 가져오고 객체를 정렬합니다.

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

common.js와 product.js를 통합하면 최종 객체는 다음과 같습니다.

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

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

5 src/plugins에 ajaxPlugin.js를 생성하고 src/main에 추가합니다. js 견적

// 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)

6. 요청 보내기:

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

이 기사는 여기서 끝났습니다. 더 많은 흥미로운 콘텐츠를 보려면 PHP 중국어 웹사이트의 JavaScript 비디오 튜토리얼 열을 참조하세요.


위 내용은 vue(코드)에서 axios 요청 캡슐화 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제