简单封装axios

目录

一、代码解读

import axios from 'axios';

创建一个名为 instance 的 Axios 实例,配置默认的请求地址和超时时间

javascript 复制代码
const instance = axios.create({
    baseURL: 'http://localhost:8085',
    timeout: 5000,
});

请求拦截器,用于在请求发送前进行处理,比如在请求头中添加 token ,在请求发送之前,如果有需要,可以在请求头中加入认证信息

javascript 复制代码
instance.interceptors.request.use(
    (config) => {
        // config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
        return config;
    },
    (error) => {
        return Promise.reject(error);
    }
);

响应拦截器,用于统一处理后端返回的错误信息

javascript 复制代码
instance.interceptors.response.use(
    (response) => {
        // 对后端返回的数据进行统一处理
        const data = response.data;
        // 如果返回的状态码不是 200,则输出错误信息到控制台
        if (data.code !== 200) {
            console.error(`Error: ${data.message}`);
        }
        return data;
    },
    (error) => {
        // 处理响应错误,输出错误信息到控制台
        console.error('Response Error:', error);
        return Promise.reject(error);
    }
);

封装 GET 请求方法,支持传入请求地址和参数

javascript 复制代码
function get(url, params = {}) {
    return instance.get(url, { params });
}

封装 POST 请求方法,支持传入请求地址和数据

javascript 复制代码
function post(url, data = {}) {
    return instance.post(url, data);
}

封装上传文件的方法,支持传入请求地址和文件

javascript 复制代码
function uploadFile(url, file) {
    // 创建一个 FormData 对象,用于上传文件
    const formData = new FormData();
    formData.append('file', file);
    // 使用 POST 方法上传文件,并设置请求头的 Content-Type 为 multipart/form-data
    return instance.post(url, formData, {
        headers: {
            'Content-Type': 'multipart/form-data',
        },
    });
}

导出封装好的 GET、POST 和上传文件的方法

javascript 复制代码
export { get, post, uploadFile };

二、整体代码

javascript 复制代码
import axios from 'axios';

const instance = axios.create({
    baseURL: 'http://localhost:8085',
    timeout: 5000,
});

instance.interceptors.request.use(
    (config) => {
        // config.headers.Authorization = `Bearer ${localStorage.getItem('token')}`;
        return config;
    },
    (error) => {
        return Promise.reject(error);
    }
);

instance.interceptors.response.use(
    (response) => {
        const data = response.data;
        if (data.code !== 200) {
            console.error(`Error: ${data.message}`);
        }
        return data;
    },
    (error) => {
        console.error('Response Error:', error);
        return Promise.reject(error);
    }
);

function get(url, params = {}) {
    return instance.get(url, { params });
}

function post(url, data = {}) {
    return instance.post(url, data);
}

function uploadFile(url, file) {
    const formData = new FormData();
    formData.append('file', file);
    return instance.post(url, formData, {
        headers: {
            'Content-Type': 'multipart/form-data',
        },
    });
}

export { get, post, uploadFile };
相关推荐
独泪了无痕2 小时前
使用Fetch API 探索前后端数据交互
前端·http·交互设计
css趣多多2 小时前
别名路径的知识点
前端
靓仔建4 小时前
Vue3导入组件出错does not provide an export named ‘user_setting‘ (at index.vue:180:10)
开发语言·前端·typescript
HalvmånEver4 小时前
7.高并发内存池大页内存申请释放以及使用定长内存池脱离new
java·spring boot·spring
EnoYao4 小时前
我写了一个团队体检报告 Skill,把摸鱼的同事扒出来了😅
前端·javascript
凤山老林4 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
梁正雄4 小时前
Python前端-2-css练习
前端·css·python
清汤饺子4 小时前
用 Cursor 半年了,效率还是没提升?是因为你没用对这 7 个功能
前端·后端·cursor
Never_Satisfied4 小时前
在JavaScript / Node.js中,package.json文件中的依赖项自动选择最新版安装
javascript·node.js·json
蓝莓味的口香糖4 小时前
【vue3】组件的批量全局注册
前端·javascript·vue.js