Vue 全局封装axios

Vue 全局封装axios

开发过程中不需要在每个组件在引用axios插件

ajax函数封装

import axios from "axios";
axios.defaults.timeout = 5000;//设置超时时间,规定时间内没有响应则执行失败回调
function ajax(obj){
  return new Promise((seccuss, error) =>{
    axios(obj).then((res) =>{
    //axios成功后根据api返回数据格式处理逻辑
      if(Number(res.data.code) === 200){
        seccuss(res.data)
      }else {
        
      }
    }).catch((e) =>{
      if (e.response) {
        console.log(e.config.url);
        console.log("错误码:"+e.response.status);
      } else if (e.request) {
        if(e.request.readyState === 4 && e.request.status === 0){
          //我在这里重新请求
          console.log(e.config.url);
          console.log("请求超时");
        }
      } else {
        console.log('Error', e.message);
      }
    })
  });
}
export default {
  install : (Vue, options) =>{
   Vue.prototype.$ajax = ajax
  }
}

main.js引用

import extend from "./extend";
Vue.use(extend);

Vue 组件中全局使用

this.$ajax({
	url:"",
	method:"",
	....
}).then(res=>{})

猜你喜欢

转载自blog.csdn.net/qq_41114603/article/details/82755536