axios请求封装,适用于RN,React,Vue,Uniapp(相对于前面几个新增个自定义header头)

axios.js

import axios from 'axios';
const instace = axios.create({
  baseURL: 'https://internal.takehr.cn', //接口地址
  timeout: 5000, //超时时间
});

//配置请求拦截器,在请求之前的数据处理,比如在请求头添加token,所有的请求都会经过拦截器
instace.interceptors.request.use(
  //config:该参数表示当前请求的配置对象
  config => {
    console.log('config', config);
    return config;
  },
  err => {
    return Promise.reject(err); //将错误消息挂到promise的失败函数上
  },
);

//配置响应拦截器
// 响应拦截器:在请求响应之后对数据处理,比如:登录失败、请求数据失败的处理
instace.interceptors.response.use(
  response => {
    return response; //这里的response就是请求成功后的res , response.data即是请求成功后回调函数内的参数res.data
  },
  err => {
    return Promise.reject(err); //将错误消息挂到promise的失败函数上
  },
);

//封装请求的api
const callapi = (method = 'GET', url, data = {}, customHeaders = {}) => {
  return instace({
    method,
    url,
    params: method === 'GET' ? data : {},
    data: method === 'POST' ? data : {},
    ...customHeaders,
  });
};
//封装GET,POST请求函数
export const getapi = (url, data, customHeaders) => callapi('GET', url, data, customHeaders);
export const postapi = (url, data, customHeaders) => callapi('POST', url, data, customHeaders);

index.js

import {getapi, postapi} from './axios';
export const login = data => postapi('/api/v1.login/signin', data); // 用户登录
export const register = data => postapi('/api/v1.login/signup', data); // 用户注册
export const SendVerificationCode = data => postapi('/api/v1.login/vertiy', data); // 使用邮箱验证码登录
export const validateResetPasswordEmail = data =>  postapi('/api/v1.login/findaccount', data); // 忘记密码邮箱校验
export const forgetPassword = data => postapi('/api/v1.login/resetPwd', data); // 忘记密码
export const photo = (data, customHeaders) => postapi('/api/upload/image', data, customHeaders);

使用

import { postapi } from './index.js'

// 参数一:请求参数
// 参数二:配置请求header头
postapi({name:Jack},{headers:{config:'...'}}).then((res)=>{
	console.log(res)
})

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-04 08:42:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-04 08:42:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-04-04 08:42:01       87 阅读
  4. Python语言-面向对象

    2024-04-04 08:42:01       96 阅读

热门阅读

  1. for in与for of的区别

    2024-04-04 08:42:01       33 阅读
  2. C语言什么是全局变量?如何应⽤?

    2024-04-04 08:42:01       33 阅读
  3. 中值滤波算法与SSE2指令集并行优化

    2024-04-04 08:42:01       36 阅读
  4. 云计算与容器化

    2024-04-04 08:42:01       40 阅读
  5. SpringMvc处理器方法参数获取

    2024-04-04 08:42:01       38 阅读
  6. 神经网络、CNN、RNN、LSTM

    2024-04-04 08:42:01       38 阅读
  7. OpenCV构建交互式图像距离测量工具

    2024-04-04 08:42:01       39 阅读
  8. python vtk获取模型角度

    2024-04-04 08:42:01       31 阅读
  9. [动态规划]代码随想录总结(自用)

    2024-04-04 08:42:01       32 阅读
  10. 限制promise并行执行个数

    2024-04-04 08:42:01       38 阅读