javascript - 用ajax模拟表单提交,遇到一个不解的问题
黄舟
黄舟 2017-04-11 09:42:20
[JavaScript讨论组]

现在,有一个网页不是我做的,也不是简单的form表单。于是我用F12工具的Network分析了一下它的表单提交,其中有这么两个键值对:

然后我就费解了。通常checkbox的提交,应该是类似这样吧:

tags[]: 7

tags[]: 128

于是我就试验。假设已经引入jQuery库。

$.post('url...', {
    ...
    tags: 7, tags: 128
    ...
}, function () {...});

测试发送,服务器只接收到到128,没有接收到7,好吧,也正常,毕竟同名的键,被覆盖了。

再试验:

$.post('url...', {
    ...
    tags: [7, 128]
    ...
}, function () {...});

测试发送,服务器报错,F12一看,键值对解析成了:

tags[]: 7

tags[]: 128

所以,到底怎样发送成这样子?

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(6)
天蓬老师

好吧,我猜一下题主可能碰到的情况。

首先,直接post一个对象是不可能的。

$.post('url', {
  tags: 7,
  tags: 128,
})

这种会被js解析字面量对象的时候覆盖掉同key的值的。

合理的解释我猜应该是在form表单中有两个同name名为'tag',然后在ajax提交的时候直接用serialize进行了序列化,最后直接ajax提交了。
所以才会出现两个字段同名的情况。

迷茫

我建议题主看一下这个请求使用form表单提交的还是用ajax提交的。form中如果有同nameinput就会出现这种情况。
Jsbin Demo

大家讲道理
$.post('url', {
  tags: 7,
  tags: 128,
})
大家讲道理

我猜测,你用的是php?php的话。checkbox[]得这样写吧?

$.post('url...', {
    tags: [7, 128]
}
这样写才是正解
PHP中文网

我理解你的问题是:为什么页面上可以,我不行?

简单的回答:因为你用的JQuery,他可能不是。

然后解释一下,你用JQuery提交数据,是JQuery帮你做了数据的序列化之类的工作,所以你就得按照JQuery的方式来提交。但,如果自己用底层的接口来发送提交数据,那么:你想数据写成什么样,就可以写成什么样。最后的问题只是如果你随意发送数据,服务器端是否能正常处理罢了。

PHP中文网

同意sfrog

jquery下你可以这样

var str='tags=7&tags=128';
$.ajax({
    type:"post",
    url:"http://localhost/",//地址自己改
    data:str,
    async:true
});

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号