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
转载随意,但请附上文章地址:-)