php获取复选框checkbox值内容实例
checkbox在html中是以数组形式存储的,如果我们要获取用户选择了我个checkbox值我们可以利用遍历或直接把数组利用implode转换在字符进行存储。
php要求同名表单元素用数组形式命名,并赋予value。否则他不能分解。
例1:利用foreach遍历checkbox
<input type=checkbox name="chk[]" value=1> <input type=checkbox name="chk[]" value=2> <input type=checkbox name="chk[]" value=3>
提交后,用$_POST['chk']访问。数组中的元素为选中的复选框的值
PHP代码:
<?php foreach ($_POST["chk"] as $i => $a) { echo $i . "==>" . $a . "<br />"; } //或者使用$_POST["chk"][0]单独使用 ?>
结果:
0=>1
1=>2
2=>3
例2利用explode
<table> <form action="index.php" method="post"> <tr> <td> <ol> <li><input type="checkbox" name="lang[]" id="lang" value="1" />中文普通话</li> <li><input type="checkbox" name="lang[]" id="lang" value="11" />日语</li> <li><input type="checkbox" name="lang[]" id="lang" value="10" />朝鲜语</li> <li><input type="checkbox" name="lang[]" id="lang" value="9" />西班牙语</li> <li><input type="checkbox" name="lang[]" id="lang" value="8" />俄语</li> <li><input type="checkbox" name="lang[]" id="lang" value="7" />德语</li> <li><input type="checkbox" name="lang[]" id="lang" value="6" />法语</li> <li><input type="checkbox" name="lang[]" id="lang" value="5" />英语</li> <li><input type="checkbox" name="lang[]" id="lang" value="4" />少数民族语言</li> <li><input type="checkbox" name="lang[]" id="lang" value="3" />中文闽南语</li> <li><input type="checkbox" name="lang[]" id="lang" value="2" />中文粤语</li> <li><input type="checkbox" name="lang[]" id="lang" value="12" />其它国家语言</li> </ol> </td> </tr> <tr> <td> <input name="submit" type="submit" value="submit" /> </td> </tr> </form> </table> <?php $CACHE['lang'] = array( '1' => '中文普通话', '11' => '日语', '10' => '朝鲜语', '9' => '西班牙语', '8' => '俄语', '7' => '德语', '6' => '法语', '5' => '英语', '4' => '少数民族语言', '3' => '中文闽南语', '2' => '中文粤语', '12' => '其它国家语言', ); $lang = $_POST['lang']; if (is_array($lang)) { $cbsports = '<ol>'; foreach ($CACHE['lang'] as $key => $val) { $cbsports.= '<li><input type="checkbox" name="lang[]" id="lang" value="' . $key . '" ' . (in_array($key, $lang) ? 'checked="checked"' : '') . ' />' . $val . '</li>'; } $cbsports.= '</ol>'; echo $cbsports; } else { echo '请勾选后提交'; } ?>
如果需要保存到数据库,按照下面的方式处理后,把$expr的值存储即可。
if(!emptyempty($lang)) { $expr = join(",", $lang); }
显示的时候再这样处理后就可以重新生成原来的数组。
$lang = explode(',',$row(lang));
备注:使用serialize() 和unserialize() 可以直接存储数组,不过字段要text类型,不太理想。
例3、需要同时删除多项,或同时修改多项记录
要点:
1,前端表单中name要加[],如:<input type="hidden" name="id[]" value="{$vo.id}">
2,后端接受如:$id = $_POST [id] [$i]; $i为for中的循环变量,当$i相同时可以使得$_POST [id] [$i]和$_POST [name] [$i]为一一对应;
一,前端表单:
<form name="form1" method="post" action="__GROUP__/Repair/updateList"> 对所选操作:<input type="submit" value="保 存" class="btn btn-primary"> <br> <table id="checkList" class="list table table-hover"> <tr> <th scope="col"><input id="check" type="checkbox" onclick="checkAll()" /> 全选</th> <th scope="col">主题</th> <th scope="col">校区</th> <th scope="col">房间</th> <th scope="col">报修人</th> <th scope="col">联系电话</th> <th scope="col">报修时间</th> <th scope="col">审核</th> <th scope="col">报修状态</th> </tr> <volist name="list" id="vo"> <tr> <td><input type="checkbox" name="key" value="{$vo.id}">{$vo.id}<input type="hidden" name="id[]" value="{$vo.id}"></td> <td>{$vo.topic}</td> <td>{$vo.xiaoqu}</td> <td>{$vo.room}</td> <td>{$vo.pname}</td> <td>{$vo.phone}</td> <td>{$vo.create_time|date='Y-m-d H:i:s',###}</td> <td><select name="check[]"><switch name="vo.check"> <case value="0"> <option value="0" selected="selected">未审核</option> <option value="1">审核</option> </case> <default /> <option value="0">未审核</option> <option value="1" selected="selected">审核</option> </switch></select></td> <td><select name="status[]"><switch name="vo.status"> <case value="已修"> <option value="未修">未修</option> <option value="任务已下">任务已下</option> <option value="已修" selected="selected">已修</option> </case> <case value="任务已下"> <option value="未修">未修</option> <option value="任务已下" selected="selected">任务已下</option> <option value="已修">已修</option> </case> <default /> <option value="未修" selected="selected">未修</option> <option value="任务已下">任务已下</option> <option value="已修">已修</option> </switch></select></td> </tr> </volist> </table> </form>
二,服务端处理代码
<?php /** * 批量修改状态 */ public function updateList() { $result = false; for ($i = 0; $i < count($_POST[id]); $i++) { $id = $_POST[id][$i]; $check = $_POST[check][$i]; $status = $_POST[status][$i]; // 保存登录信息 $Repair = M('Repair'); $data['id'] = $id; $data['check'] = $check; $data['status'] = $status; $result = $Repair->save($data); } if (false !== $result) { $this->success('修改成功!'); } else { $this->error('修改失败!'); } }
本文地址:http://www.phprm.com/develop/54980.html
转载随意,但请附上文章地址:-)