php批量修改数据时input[type=checkbox]发生的有关问题
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php批量修改数据时input[type=checkbox]发生的有关问题,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1762字,纯文字阅读大概需要3分钟。
内容图文
php 批量修改数据时 input[type=checkbox]发生的问题本帖最后由 sky94132003 于 2014-12-07 23:45:24 编辑 input[type=checkbox] 我用了js 把 数值 'On' 转成了方便我输入数据库的 1 和 0
$('input[type="checkbox"]').change(function(){
this.value ^= 1;
});
表单太复杂,就不贴上来了
反正所有栏位我也填上了 name[]
问题来了,我除了 $_POST["blank"]; 这个栏位其他都可以正常地批量更新
不是不能更新,是更新的次序有问题
以下是个详细的测试,比如页面上有5条数据可以批量修改
1. ID1~5 设定$_POST["blank"] = 1 (打勾)
成功
2. ID1~5 设定$_POST["blank"] = 0 (不打勾)
成功
3. 把 ID 2,3 设定$_POST["blank"] = 1
ID 1,2会变成 1 反而3没有改变
4. 再试试... 把ID 3,4,5 设定$_POST["blank"] = 1 (事先将全部设定回0)
结果不出所料,是ID 1,2,3 变成 blank = 1,而ID4 5 没有改变
理论上,PHP是知道我有多少个设定为blank = 1,但终是只把排序最前面的定设为1
感觉上是array指针不对之类的? 但这又为什么其他栏位都非常准确正常地可以更新修改? 只有这个栏不能修改?
最烦恼的是知道怎样发生错误,但一直查不出原因来
if (isset($_POST["edit_menu"])) {
$gid =$_POST["gid"];
$sql = "";
$menuCount = count($_POST["id"]);
for($i=0;$i<$menuCount;$i++) {
$title = $_POST["title"];
$url = $_POST["url"];
$id = $_POST["id"];
$blank = $_POST["blank"];
$sql .= "UPDATE `menu` set
title='" . $title[$i] . "',
url='" . $url[$i] . "',
blank='" . $blank[$i] . "'
WHERE id='" . $id[$i] . "' AND gid = '$gid';";
}
$stmt = $pdo->exec($sql);
}
------解决思路----------------------
没有被勾选的 checkbox 是不会被提交的!
php 只知道有多少个 checkbox 被选中,但不知道选中的是哪些
所以你需要通过指定 checkbox 的 value 来识别被选中的 checkbox,而不是让他做0、1转换
checkbox.value 通常是备选项的序号或 id
内容总结
以上是互联网集市为您收集整理的php批量修改数据时input[type=checkbox]发生的有关问题全部内容,希望文章能够帮你解决php批量修改数据时input[type=checkbox]发生的有关问题所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。