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

axios.js

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

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);

使用

js 复制代码
import { postapi } from './index.js'

// 参数一:请求参数
// 参数二:配置请求header头
postapi({name:Jack},{headers:{config:'...'}}).then((res)=>{
	console.log(res)
})
相关推荐
梵得儿SHI13 小时前
Vue 模板语法深度解析:从文本插值到 HTML 渲染的核心逻辑
前端·vue.js·html·模板语法·文本插值·v-text指令·v-html指令
浪裡遊13 小时前
HTML面试题
前端·javascript·react.js·前端框架·html·ecmascript
More more14 小时前
uniapp实时查看在线监控,JessibucaMobile实现横屏播放
前端·javascript·uni-app·jessibucamobile
好想早点睡.14 小时前
vue2+UniApp微信小程序集成高德地图
微信小程序·小程序·uni-app
i小杨14 小时前
React 状态管理库相关收录
前端·react.js·前端框架
PyAIGCMaster14 小时前
ERR_PNPM_ENOENT ENOENT: no such file or directory, scandir的解决方案
react.js
Jiaberrr14 小时前
解决uni-app通用上传与后端接口不匹配问题:原生上传文件方法封装 ✨
前端·javascript·uni-app
listhi52014 小时前
Vue.js 3的组合式API
android·vue.js·flutter
WYiQIU15 小时前
高级Web前端开发工程师2025年面试题总结及参考答案【含刷题资源库】
前端·vue.js·面试·职场和发展·前端框架·reactjs·飞书
夏之小星星15 小时前
Springboot结合Vue实现分页功能
vue.js·spring boot·后端