js封装axios

以下是一个简单的封装axios的示例代码:

import axios from 'axios';

/**
 * 自定义封装axios实例
 */
const request = axios.create({
  baseURL: 'https://api.example.com', // 设置基础URL
  timeout: 5000, // 超时时间
});

/**
 * 请求拦截器
 */
request.interceptors.request.use(
  (config) => {
    // 在请求发送之前做些什么
    // 可以在这里设置请求头等信息
    return config;
  },
  (error) => {
    // 对请求错误做些什么
    return Promise.reject(error);
  }
);

/**
 * 响应拦截器
 */
request.interceptors.response.use(
  (response) => {
    // 对响应数据做些什么
    return response.data;
  },
  (error) => {
    // 对响应错误做些什么
    return Promise.reject(error);
  }
);

export default request;

上述代码中,我们首先通过 import 引入了 axios 模块,然后使用 axios.create() 方法创建了一个自定义的 axios 实例,该实例可以配置基础 URL、超时时间等。

接着,我们分别定义了请求拦截器和响应拦截器。在请求拦截器中,我们可以对请求进行一些处理,比如设置请求头等信息;在响应拦截器中,我们可以对响应进行处理,并返回处理后的数据。

最后,我们使用 export default 导出了定义好的 request 实例,以便在其他文件中使用。

接下来我们可以使用上面封装好的 axios 实例进行请求。

假设我们要请求一个后端 API,获取用户信息,可以参考如下代码:

import request from './request'; // 引入自定义的axios实例

/**
 * 获取用户信息
 * @param {string} userId 用户ID
 */
export function getUserInfo(userId) {
  return request.get('/user/info', {
    params: {
      userId,
    },
  });
}

 接着,我们就可以在其他地方调用 getUserInfo() 函数来获取用户信息,例如:

import { getUserInfo } from './api'; // 引入API接口

getUserInfo('123456').then((res) => {
  console.log(res); // 打印获取到的用户信息
});

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端程序猿i

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值