axios拦截封装,get、post二次封装

最近开发了一个PC端的新项目,从0到1,所以对基础的一些配置要进行封装,例如axios,我为什么要写这篇文章记录呢,是因为我在进行get请求封装的时候犯了一个错误(get请求的传参一定要加params,这个是固定的写法),所以记录下来。
直接上代码:
request.js(axios的封装放置的文件)

import axios from 'axios'
const baseURL = import.meta.env.VITE_APP_BASE_URL


const service = axios.create({
    baseURL: baseURL, // url = base url + request url
    timeout: 100000, // request timeout
    headers:{
        "Content-Type": "application/json",
        "token": new URLSearchParams(location.search).get('token'),
    }
})

//http request 拦截器
service.interceptors.request.use(
    config => {
        config.data = JSON.stringify(config.data);
        //设置请求头
        config.headers = {
            'Content-Type': 'application/x-www-form-urlencoded'
        };
        return config;
    },
    error => {
        return Promise.reject(err);
    }
);
 
//http response 拦截器
service.interceptors.response.use(
    response => {
        const res = response.data
        if (res.code !== 000000) {
             console.log('接口信息报错', res.message)
             return Promise.reject(new Error(res.message || 'Error'))
         } else {
             return res.data
         }
    },
    error => {
        return Promise.reject(error)
    }
);

/**
 * 封装get方法
 * @param url
 * @param data
 * @returns {Promise}
 */
 // 记住get请求中,params是固定的写法,一定要记住这一点
export function get(url, params = {}) {
    return new Promise((resolve, reject) => {
        service.get(url, {
                params: params
            })
            .then(response => {
                resolve(response.data);
            })
            .catch(err => {
                reject(err)
            })
    })
}
 
/**
 * 封装post请求
 * @param url
 * @param data
 * @returns {Promise}
 */
export function post(url, data = {}) {
    return new Promise((resolve, reject) => {
        service.post(url, data)
            .then(response => {
                resolve(response.data);
            }, err => {
                reject(err)
            })
    })
}

吃一堑长一智,记住get请求中,params是固定的写法,一定要记住这一点

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是基于axios进行二次封装的get和post请求的代码示例: ```javascript import axios from 'axios'; // 创建axios实例 const service = axios.create({ baseURL: 'http://localhost:3000', // api的base_url timeout: 5000 // 请求超时时间 }); // request拦截器 service.interceptors.request.use(config => { // 在发送请求之前做些什么 return config; }, error => { // 对请求错误做些什么 console.log(error); // for debug Promise.reject(error); }); // respone拦截器 service.interceptors.response.use( response => { const res = response.data; // 如果返回的状态码不是200,说明接口请求失败或者权限校验失败 if (res.code !== 200) { // 这里可以跳转到错误页面 console.log(res.msg); } else { return response.data; } }, error => { console.log('err' + error); // for debug // 这里可以跳转到错误页面 return Promise.reject(error); } ); // get请求 export function get(url, params) { return service({ url: url, method: 'get', params: params }); } // post请求 export function post(url, data) { return service({ url: url, method: 'post', data: data }); } ``` 在使用时,只需要引入封装好的get和post方法,然后传入相应的参数即可,例如: ```javascript import { get, post } from './api.js'; // get请求示例 get('/api/user', { id: 1 }) .then(res => { console.log(res); }) .catch(err => { console.log(err); }); // post请求示例 post('/api/login', { username: 'admin', password: '123456' }) .then(res => { console.log(res); }) .catch(err => { console.log(err); }); ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值