使用axios.delete时后台接收不到参数

这几天在学习使用 axios 的时候发现一个问题,在使用 axios.post 和 axios.put 时,后台均可以通过 req.body 访问到参数,但是使用 axios.delete 时后台却无法接收到参数,而网上无人解答此问题,难道大家都只用 axios.post 吗,但是我又很犯贱,偏想要用 delete,无奈之下只好去查看源码,但是作为菜鸟,我很少去看源码这种东西,看了半天,终于发现了问题
在这里插入图片描述
各位观众,看到没有,delete 和 post 、put 的参数不一样,post、put都有三个参数,分别为url、data还有config,而delete只有两个参数,第一个是url,第二个是config,我又去看config所实现的接口类型
在这里插入图片描述
这个接口里面也有一个data,突然间我就明白了,我之前发请求时是这样调用的 axios.post(’/api’,{id:1}) 、axios.put(’/api’,{id:1}),我原以为delete应该也是这样调用 axios.delete(’/api’,{id:1}) ,但后台却接收不到,是因为 post 和 put 第二个参数是data,所以可以直接在第二个参数的位置写上数据,后台可以访问到,而delete第二个参数是 config ,所以要通过 config 里面的 data 来传参,所以应该这样写:

axios.delete(’/api’,{data:{id:1}})

在数据的外面包一个data就可以了

附上代码:

# js文件

# post请求
export const Add_samwebVideo_specia = params => { return axios.post(`${base}/samweb/samwebVideo_specia/`, params); };
# get请求
export const Get_samwebVideo_specia= params => { return axios.get(`${base}/samweb/samwebVideo_specia/`, { params: params } ); };
# put请求
export const Act_activate_specia = params => { return axios.put(`${base}/samweb/activate_specia/`, params ); };
# delete请求
export const Delete_samwebVideo_specia  = params => { return axios.delete(`${base}/samweb/samwebVideo_specia/`, { data: params }); };

# vue文件
delete_peaic:function(){
    var data = new FormData();
    data.append('id', this.$route.query.id);
    data.append('specaList', this.specaList);
    Delete_samwebVideo_specia(data).then(res=>{
        if(res.data.code==200){
            this.$message({
              message: res.data.message,
              type: 'success'
            });
            this.List_video_peaic()
        }else {
            this.$message({
              message: res.data.message,
              type: 'success'
            });

        }
    })
},

转载自: https://blog.csdn.net/qq383366204/article/details/80268007

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值