900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > php 批量修改数据时 input[type=checkbox]发生的有关问题

php 批量修改数据时 input[type=checkbox]发生的有关问题

时间:2019-06-28 05:26:14

相关推荐

php 批量修改数据时 input[type=checkbox]发生的有关问题

后端开发|php教程

nbsp,blank,checkbox,POST,ID

后端开发-php教程

php 批量修改数据时 input[type=checkbox]发生的问题

自定义 网址导航 源码,ubuntu16 网卡,tomcat启动乱码淇 伅,python爬虫学习感受,php怎么用转义字符换行,阳江谷歌seolzw

本帖最后由 sky9413 于 -12-07 23:45:24 编辑

android 仿大众点评网源码,vscode 单步调试,ubuntu 左边消失,tomcat短暂无响应,山药爬虫,php 读取access,搜索信息调到seo搜索,阿里云主机下载网站源码,php t模板下载地址lzw

input[type=checkbox] 我用了js 把 数值 ‘On’ 转成了方便我输入数据库的 1 和 0

有什么游戏赚钱的网站源码,ubuntu安装时卡在,tomcat绿色版扩展内存,爬虫价格排行,项目管理系统php源码,贵州seo方案lzw

$(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 AND gid = $gid;";

}

$stmt = $pdo->exec($sql);

}

——解决思路———————-

没有被勾选的 checkbox 是不会被提交的!

php 只知道有多少个 checkbox 被选中,但不知道选中的是哪些

所以你需要通过指定 checkbox 的 value 来识别被选中的 checkbox,而不是让他做0、1转换

checkbox.value 通常是备选项的序号或 id

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。