避免axios自动过滤空字符串的字段

  • axios好像并不会过滤空字符串,不管啥内容只要给了都会被提交,接收不到的原因可能是你接口名和提交的key没对上
  • JSON.stringify(),会自动去掉值为undefined的字段
  • 空字符串不会被过滤,会过滤undefined

原文链接https://www.h5w3.com/149010.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
问题可能出在前后端数据传输的格式不一致导致的。axios默认的请求Content-Type是"application/json",因此它会将传递的数据自动进行JSON序列化处理。而后端可能需要接收普通的字符串数据,而不是JSON对象。 解决这个问题有两种方法: 1. 前端改变数据传输格式:在发送请求时,通过设置请求头的Content-Type为"application/x-www-form-urlencoded",并将字符串数据作为键值对的形式进行传递。代码可以如下所示: ```javascript axios.post('/api/endpoint', `data=${encodeURIComponent(yourStringData)}`, { headers: { 'Content-Type': 'application/x-www-form-urlencoded' } }) ``` 2. 后端改变数据接收方式:后端可以使用相应的方式接收JSON数据并进行处理。比如在Node.js中,可以使用`body-parser`中间件对请求体进行解析。代码可以如下所示: ```javascript const express = require('express'); const bodyParser = require('body-parser'); const app = express(); app.use(bodyParser.json()); // 解析 application/json 请求 app.use(bodyParser.urlencoded({ extended: true })); // 解析 application/x-www-form-urlencoded 请求 app.post('/api/endpoint', (req, res) => { const data = req.body.data; // 获取传递的字符串数据 console.log(data); // 其他处理逻辑 }); app.listen(3000, () => { console.log('服务器已启动...'); }); ``` 通过以上方法,可以确保前后端数据传输格式的一致性,从而正确接收和处理字符串数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值