axios 二次封装

axios 二次封装

基本上每一个项目开发,都必须要二次封装 axios。主要是为了减少重复性工作,不可能每一次发起新请求时,都要重新配置请求域名、请求头 Content-Type、Token 等信息。所以需要把公用的部分都封装成一个函数,每次调用的时候只需要传入变化的参数。

:::warning 注意

基于上个案例在继续做优化,如需要请查看 axios 响应拦截器

:::

封装

src/plugins/axios.js

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

/**
 * 请求拦截器
 */
axios.interceptors.request.use((config) => {
    config.data = qs.stringify(config.data)

    return config
})

/**
 * 响应拦截器
 */
axios.interceptors.response.use((response) => {
    if (response.data.code !== 200) {
        alert('接口响应失败')
    }

    return response.data
})

/**
 * 接口请求方法
 */
const request = (method, option) => {
    return axios({
        method: method,
        url: 'https://study.noxussj.top' + option.url,
        data: option.data,
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded'
        }
    })
}

export default {
    get: (option) => request('get', option),
    post: (option) => request('post', option),
    put: (option) => request('put', option)
}

调用

这样每次发起请求时,只需要把 二次封装的 axios 引入进来使用即可。可以大幅减少代码数量。

javascript 复制代码
import axios from './plugins/axios.js'

/**
 * 发起请求
 */
const p1 = axios.post({
    url: '/api/login',
    data: { account: 'test', password: '123456' }
})

p1.then((res) => {
    console.log(res.data)
})

原文链接:菜园前端

相关推荐
William Dawson1 分钟前
【Vue 3 + Element Plus 实现产品标签的动态添加、删除与回显】
前端·javascript·vue.js
拉不动的猪10 分钟前
项目基础搭建时的一些基本注意点
前端·javascript·面试
蕉君桑19 分钟前
vue2使用vue-echarts
前端·vue.js·echarts
runnerdancer37 分钟前
React+Vite+Typescript项目脚手架模版
前端
Code额1 小时前
ECMAScript 6 新特性(二)
前端·javascript·ecmascript
群联云防护小杜2 小时前
基于AI的Web应用防火墙(AppWall)实战:漏洞拦截与威胁情报集成
前端·分布式·安全·ddos
_清浅2 小时前
JavaScript(JS进阶)
开发语言·前端·javascript·操作系统·html5
葡萄城技术团队2 小时前
如何通过前端表格控件实现自动化报表?1
运维·前端·自动化
CharlesYu012 小时前
vite作者如何评价turbopack
前端·turbopack
小王码农记2 小时前
vue中动态绑定ref后,获取某个具体组件实例
前端·javascript·vue.js