request_blob.js 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. import axios from 'axios'
  2. import { Message, Loading } from 'element-ui'
  3. import store from '@/store'
  4. import { getToken } from '@/utils/auth'
  5. // create an axios instance
  6. const service = axios.create()
  7. let loadingInstance
  8. // request interceptor
  9. service.interceptors.request.use(
  10. config => {
  11. if (store.getters.token) {
  12. config.headers['token'] = `${getToken()}`
  13. }
  14. loadingInstance = Loading.service({
  15. lock: false,
  16. customClass: 'z-index999',
  17. text: '加载中,请稍后...',
  18. spinner: 'ui-icon-loading',
  19. background: 'rgba(0, 0, 0, 0.7)'
  20. })
  21. return config
  22. },
  23. error => {
  24. // do something with request error
  25. return Promise.reject(error)
  26. }
  27. )
  28. // response interceptor
  29. service.interceptors.response.use(
  30. /**
  31. * If you want to get http information such as headers or status
  32. * Please return response => response
  33. */
  34. /**
  35. * Determine the request status by custom code
  36. * Here is just an example
  37. * You can also judge the status by HTTP Status Code
  38. */
  39. response => {
  40. loadingInstance.close()
  41. return response
  42. },
  43. error => {
  44. loadingInstance.close()
  45. console.log('err' + error) // for debug
  46. Message({
  47. message: error.message,
  48. type: 'error',
  49. duration: 5 * 1000,
  50. offset: 112
  51. })
  52. return Promise.reject(error)
  53. }
  54. )
  55. export default service