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 />"; }
-
- ?>
-
- 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 ( '修改失败!' );
- }
- }