vue实现对axios拦截

作者:李李
链接:https://www.zhihu.com/question/588006994/answer/2948238220
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

import axios from "axios";
import config from "../config";
import { ElMessage } from "element-plus";
import router from "../router";
import storage from "./storage";

const NETWORK_ERROR = "网络请求异常,请稍后再试";

const instance = axios.create({
  baseURL: config.baseApi,
  timeout: 8000,
});

//请求拦截
instance.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  const headers = config.headers;
  if(storage.getItem('userInfo')){
    const {token} = storage.getItem('userInfo').data || {token:''};
    if (!headers.Authorization) headers.Authorization = "Bearer " + token; //jwt
  }
  return config;
});

//响应拦截
instance.interceptors.response.use(function (response) {
  const { code, msg } = response.data; //状态码  接口  HTTP
  if (code === 200) {
    response.data;
  } else if (code === 50001) {
    ElMessage.error(msg);
    setTimeout(() => {
      router.push("/login");
    }, 3000);
    return Promise.reject(msg);
  } else {
    ElMessage.error(msg || NETWORK_ERROR);
  }
  return response;
});

function request(options) {
  options.method = options.method || "get";
  if (options.method.toLowerCase() == "get") {
    options.params = options.data;
  }

  let isMock = config.mock;
  if(toString.call(options.mock) != '[object Undefined]'){
    isMock = options.mock;
  }

  if (config.env === "prod") {
    instance.defaults.baseURL = config.baseApi;
  } else {
    instance.defaults.baseURL = isMock ? config.mockApi : config.baseApi;
  }
  return instance(options);
}

["get", "post", "put", "delete"].forEach((item) => {
  request[item] = (url, data, mock) => {  //mark flag true  mock
    if(data == undefined){
      data = {};
    }

    if(typeof data == 'boolean'){
      mock = data;
      data = {};
    }
   
    return request({
      url,
      data,
      mock,
      method: item,
    });
  };
});

export default request;

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
新版本的Vue已经不再内置axios,而是推荐使用vue-axios插件,它是axiosVue插件形式。所以,如果你使用的是新版本的Vue,你需要手动安装vue-axios并在项目中使用它才能拦截请求。 首先,你需要安装vue-axios插件。你可以在终端中运行以下命令来安装它: ``` npm install vue-axios ``` 安装完成后,你需要在你的主文件(通常是main.js)中导入vue-axios并将它作为Vue的插件使用,以便在整个应用程序中使用它。代码如下: ```javascript import Vue from 'vue' import axios from 'axios' import VueAxios from 'vue-axios' Vue.use(VueAxios, axios) ``` 接下来,你可以在你的组件中使用vue-axios来发起请求并添加拦截器。你可以这样做: ```javascript import axios from 'axios' axios.interceptors.request.use( function(config) { // 在请求发送之前做一些处理 return config }, function(error) { // 请求错误时做一些处理 return Promise.reject(error) } ) axios.interceptors.response.use( function(response) { // 对响应数据做一些处理 return response }, function(error) { // 对错误响应做一些处理 return Promise.reject(error) } ) ``` 请注意,你在这个例子中使用的是全局的axios实例,它不再是Vue的插件。所以你需要手动导入axios并使用它。 使用这种方式,你的新版本Vue中的axios拦截器就可以正常使用了。拦截器将在请求发送之前和响应返回之后进行处理,让你可以对请求和响应进行自定义操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值