封装axios的get、post方法

简介: 本文介绍了如何封装axios的get和post方法,并展示了具体的代码实现,包括使用axios创建实例、设置请求拦截器以及定义get和post函数。

对axios的封装

import axios from 'axios'
import {
    ElMessage } from "element-plus";
import store from '../../store/index'
import router from '../../router'
let Ajax = axios.create({
   
    baseURL: "http://127.0.0.1:8000/",
    timeout: 50000
})
Ajax.interceptors.request.use(config => {
   
    config.cancelToken = new axios.CancelToken(cancel => {
   
        store.commit('home/add_AxiosPromiseArr', {
    cancel })
    })
    // Do something before request is sent
    return config;
}, error => {
   
    return Promise.reject(error);
});
Ajax.interceptors.response.use(response => {
   
    if (response?.data?.data?.code == 2) {
   
        ElMessage(response.data.data.data)
        router.push('/login')
        localStorage.clear()
        return []
    }
    if (response?.data?.data?.code == 0) {
   
        ElMessage(response.data.data.data)
        router.push('/login')
        localStorage.clear()
        return []
    }
    return response.data;
}, error => {
   
    return Promise.reject(error);
});

const get = (url, params) => {
   
    Ajax.defaults.headers['token'] = localStorage.getItem('token')
    return new Promise((relove, reject) => {
   
        Ajax.get(url, {
    params, headers: {
    responseType: 'arraybuffer' } }).then(res => relove(res)).catch(err => reject(err))
    })
}
const getTIP = (url, params) => {
   
    Ajax.defaults.headers['token'] = localStorage.getItem('token')
    return new Promise((relove, reject) => {
   
        Ajax.get(url, {
    params, responseType: "arraybuffer", headers: {
    responseType: 'arraybuffer' } }).then(res => relove(res)).catch(err => reject(err))
    })
}
const post = (url, params) => {
   
    Ajax.defaults.headers['token'] = localStorage.getItem('token')
    return new Promise((relove, reject) => {
   
        Ajax.post(url, params).then(res => relove(res)).catch(err => reject(err))
    })
}
export default {
   
    get, post, getTIP
}
目录
相关文章
|
2月前
|
资源调度 JavaScript 前端开发
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
这篇文章是关于如何在Vue项目中使用axios进行网络请求、二次封装axios以及使用mockjs模拟响应数据的教程。
96 1
vue-element-admin 综合开发四:axios安装和封装、mock安装/学习/使用
|
1月前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
53 2
|
29天前
|
JavaScript 前端开发 Java
SpringBoot项目的html页面使用axios进行get post请求
SpringBoot项目的html页面使用axios进行get post请求
37 0
|
2月前
|
Python
axios的get请求传入数组参数
【10月更文挑战第11天】 当使用 `axios` 发送包含数组参数的 GET 请求时,默认的序列化方式可能与后端(如 Django)不兼容,导致无法正确获取数组参数。解决方案是通过 `paramsSerializer` 指定自定义序列化函数,或使用 `qs` 库来格式化数组参数,确保前后端一致。示例代码展示了如何使用 `qs` 库设置 `arrayFormat` 为 `"repeat"`,以符合 Django 的解析要求。
86 2
|
2月前
|
前端开发 JavaScript API
自己动手封装axios通用方法并上传至私有npm仓库:详细步骤与实现指南
自己动手封装axios通用方法并上传至私有npm仓库:详细步骤与实现指南
117 0
|
2月前
|
资源调度 JavaScript
|
4月前
|
JavaScript 前端开发
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
这篇文章主要讨论了axios的使用、原理以及源码分析。 文章中首先回顾了axios的基本用法,包括发送请求、请求拦截器和响应拦截器的使用,以及如何取消请求。接着,作者实现了一个简易版的axios,包括构造函数、请求方法、拦截器的实现等。最后,文章对axios的源码进行了分析,包括目录结构、核心文件axios.js的内容,以及axios实例化过程中的配置合并、拦截器的使用等。
【Vue面试题二十五】、你了解axios的原理吗?有看过它的源码吗?
|
2月前
|
缓存 JavaScript 搜索推荐
|
4月前
|
JavaScript 前端开发
【Vue面试题二十七】、你了解axios的原理吗?有看过它的源码吗?
文章讨论了Vue项目目录结构的设计原则和实践,强调了项目结构清晰的重要性,提出了包括语义一致性、单一入口/出口、就近原则、公共文件的绝对路径引用等原则,并展示了单页面和多页面Vue项目的目录结构示例。
|
3月前
|
JavaScript 前端开发 开发者
vue中使用axios请求post接口,请求会发送两次
vue中使用axios请求post接口,请求会发送两次