我用javascript和php创建了一个表单。我使用了一个文本框,例如
<input type="textbox" name="listid" value="" />
我将从 $_POST['listid'] 获得一个像 4,6,12,9 等这样的数组;我可以使用序列化将此值插入数据库,并通过反序列化来检索它。但是我需要做的是,插入 1 表示 listid=4,2 表示 listid=6,3 表示 listid=12,4 表示 listid=9。我用过
$count=0;
foreach($_POST['listid]' as $id)
{
$count++;
$db->update('lists',array('order'=>$count),'id ='.$db->quote($id));
}
但它不起作用。仅更新第一个值(列表 ID = 4)
我需要做什么?有人请帮忙吗??
谢谢!
你不会从$_POST['listid]收到一个数组,你会得到一个字符串。首先将该字符串拆分为一个数组,然后实现逻辑。
$arrListId = split(',', $_POST['listid]);
试试这个。
<?php
$count=0;
foreach($_POST['listid'] as $id)
{
$count++;
$db->update('lists',array('order'=>$count),'id ='.$db->quote($id));
}
?>
删除 $count=0;脱离 for 循环
你可以试试
$count=0;
foreach($_POST['listid]' as $id)
{
$count++;
$data = array('order'=>$count);
$db->update('lists',$data,$this->_db->quoteInto('id = ?',$id));
}
我希望这可能有效