vue使用axios调用api接口 ---- 关于qs序列化

常见的Content-Type: application/x-www-form-urlencoded 当设置好Content-Type参数不进行序列化你会发现还是走的json方式请求。

举例:

var params = {
                    pageIndex : that.packnowpage,
                    customName : that.packsearchinfo,
                };
                that.$axios
                .post(`${this.$APIURL}/upgradePackage/list`,params,{headers:{'Content-Type':'application/x-www-form-urlencoded'}})
                .then(response => {
                    const { data } = response                
                    if(data.code=="0")
                    {
                        console.log(data);
                        //赋值
                        that.packData = data.data.list;
                        that.packnowpage = data.data.pageNum;
                        that.packcountpage = data.data.pages;                  
                    }
                    else
                    {
                        this.$message.error(data.msg);
                    }
                }).catch(error => {
                    this.$message.error(error);
                })
that.$axios.post(
`${this.$APIURL}/upgradePackage/list`,
params,
{headers:{'Content-Type':'application/x-www-form-urlencoded'}})

正确写法:
that.$axios.post(
`${this.$APIURL}/upgradePackage/list`,
qs.stringify(params),
{headers:{'Content-Type':'application/x-www-form-urlencoded'}})




关于qs

在项目中使用命令行工具输入:npm install qs
安装完成后在需要用到的组件中:import qs from 'qs’
具体使用中我查看了:qs.parse()和qs.stringify()

这两种方法虽然都是序列化,但是还是有区别的。
qs.parse()是将URL解析成对象的形式
qs.stringify()是将对象 序列化成URL的形式,以&进行拼接

解决我遇到的问题我使用了qs.stringify()





posted @ 2020-09-14 10:52  一介桃白白  阅读(495)  评论(0编辑  收藏  举报