vue2.0中axios请求配置

vue2.0中axios请求配置

一、vue2.0项目中

1.配置

javascript 复制代码
// axios.js
import axios from 'axios';
import { Message } from 'element-ui';
import router from '../../router/index.js';
//创建axios实例

const service = axios.create({
  timeout: 600000, // 请求超时时间
  withCredentials: false,
});
//请求拦截
service.interceptors.request.use(
  config => {
    config.headers['Content-Type'] = 'application/json';
    config.headers['aiToken'] = JSON.parse(localStorage.getItem('token'));
    config.url = process.env.VUE_APP_WEB_API + config.url;
    // get请求缓存处理
    if (config.params) {
      config.params.f_rnd = new Date().getTime();
    } else {
      config.params = {
        f_rnd: new Date().getTime(),
      };
    }
    return config;
  },
  error => {
    return Promise.reject(error);
  }
);

//响应拦截器
service.interceptors.response.use(
  response => {
    let data = response.data;
    if (response.config.isExport) {
     //配置是为了下载返回二进制文档流时候
      return response;
    }
    if (data.code === 200) {
      return data;
    } else {
      if (data.code === 1015) {
        Message({
          type: 'error',
          offset: 12,
          message: '登录/授权已经过期,请重新登录',
          duration: 5000,
        });
        router.push({ path: '/login' });
        return;
      }
      Message({
        showClose: true,
        message: data.message || data.msg,
        duration: 2000,
        type: 'error',
      });
      return Promise.reject(data);
    }
    // return data;
  },
  error => {
    console.log('error:' + error); // 用于调试
    return Promise.reject(error);
  }
);

export default service;

2.使用

javascript 复制代码
// api.js
import request from '@/assets/js/axios.js';


export function wordClould(params) {
  return request({
    url: `url`,
    method: 'get',
    params,
  });
}

export function adviserWordClould(data) {
  return request({
    url: 'url',
    method: 'post',
    data,
  });
}

二、vue2.0+ts项目中如何配置

1.配置

javascript 复制代码
// axios.ts
import axios from 'axios';
import { AxiosResponse, InternalAxiosRequestConfig, AxiosError } from 'axios';
import { Message } from 'element-ui';

const request = axios.create({
  timeout: 50000,
  withCredentials: false,
});

/**
 **********************************请求拦截
 */
request.interceptors.request.use(
  //在函数中使用名为 config 的参数,并且该参数必须符合 InternalAxiosRequestConfig<any> 这个自定义类型的定义。
  function (config: InternalAxiosRequestConfig<any>) {
    // Do something before request is sent
    if (config.headers) {
      config.headers['Authorization'] = 'token';
    }
    config.url = process.env.VUE_APP_WEB_API + config.url;
    return config;
  },
  function (error: AxiosError) {
    // Do something with request error
    return Promise.reject(error);
  }
);

// 名为 status 的数值属性
interface responseConfig {
  // 响应结果包含status,0 是成功
  status: number;
}
/**
 ********************************** 响应拦截
 */
request.interceptors.response.use(
  function (response: AxiosResponse<responseConfig>) {
    if (response.data.status === 200) {
      return response;
    }

    Message.error('后台接口异常,请联系管理员');
    return Promise.reject(response);
  },
  function (error: AxiosError) {
    return Promise.reject(error);
  }
);

export default request;

2.使用

javascript 复制代码
// types.ts

/**
 * 任意类型的参数
 */
export interface paramsType {
  [key: string]: any;
}
javascript 复制代码
// api.ts
import request from '../utils/axios';
import { paramsType } from '../utils/types';

/**
 * 登录接口
 * @param userData
 * @returns
 */
export function ApiLogin(data: paramsType) {
  return request({
    method: 'POST',
    url: 'url',
    data,
  });
}

/**
 * 获取菜单
 * @param params
 * @returns
 */
export function APIGetMenu(params: paramsType) {
  return request({
    method: 'GET',
    url: 'url',
    params,
  });
}
相关推荐
凡人叶枫12 分钟前
Effective C++ 条款30:透彻了解 inlining 的里里外外
linux·开发语言·c++·嵌入式开发·effective c++
学逆向的37 分钟前
C++纯虚函数
开发语言·c++·网络安全
程序员二叉1 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉1 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
凡人叶枫2 小时前
Effective C++ 条款22:将成员变量声明为 private
linux·开发语言·c++
Qt程序员2 小时前
掌握 Linux 内核调度:从原理到实现(进程篇)
java·开发语言
code bean2 小时前
【LangChain】检索器完全指南:从向量检索到生产级 RAG 架构
java·开发语言·微服务
LabVIEW开发2 小时前
LabVIEW + MATLAB 混合编程:爆炸场测试数据精准采集方案
开发语言·matlab·labview
嵌入式协会20240722 小时前
(已解决)MinIO python 获取预签名出现forbidden、errornetwork等错误
java·开发语言·python
宸丶一2 小时前
Day 14:任务追踪 - 让 Agent 拥有项目管理能力
开发语言·python