php获取复选框checkbox值内容实例

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

时间: 2024-10-25 03:52:42

php获取复选框checkbox值内容实例的相关文章

jquery获取复选框checkbox的值实现方法_jquery

jQuery API : each(callback)::以每一个匹配的元素作为上下文来执行一个函数. :checked :匹配所有选中的被选中元素(复选框.单选框等,不包括select中的option) js: //js获取复选框值 var obj = document.getElementsByName("interest");//选择所有name="interest"的对象,返回数组 var s='';//如果这样定义var s;变量s中会默认被赋个null值

jquery获取复选框checkbox的值的简单实现方法_jquery

jQuery API : each(callback) :以每一个匹配的元素作为上下文来执行一个函数. :checked :匹配所有选中的被选中元素(复选框.单选框等,不包括select中的option) js: //js获取复选框值 var obj = document.getElementsByName("interest");//选择所有name="interest"的对象,返回数组 var s='';//如果这样定义var s;变量s中会默认被赋个null值

jquery是如何获取复选框的值

 获取复选框的值的方法有很多,举不胜举,在本文将为大家介绍下jquery是如何获取复选框的值的,感兴趣的朋友不要错过 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  <html>  <head>  <mce:style><!--  -->

JS获取复选框的值,并传递到后台的实现方法_javascript技巧

给复选框命名:<input type='checkbox' name='checkTheme' value='"> 我在提交的时候onclick="aa();" function aa() { var bb = ""; var temp = ""; var a = document.getElementsByName("checkTheme"); for ( var i = 0; i < a.len

jquery获取复选框的值的简单实例_jquery

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <mce:style><!-- --></mce:style><style mce_bogus="1"> </style>

简单php获取复选框的值代码

 代码如下 复制代码 <html> <head> <title>获取复选框的值</title> </head> <body> <form action="result.php" method="POST"> <input type="checkbox" name="year[]" value="1">1    &

动态获取复选框checkbox选中个数的jquery代码_jquery

今天碰到"jquery动态获取复选框checkbox选中的个数",首先看下面例子: 复制代码 代码如下: <input type="checkbox" checked="checked">python<br> <input type="checkbox" checked="checked">java<br> <input type="check

jquery如何获取复选框的值_jquery

复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <mce:style><!-- --></mce:style><style mce_bogus="1"> &l

jsp获取复选框的值并保存数据库

从JSP页面获取复选框的values值,通过定义数组,将其值存入数组之中,并显示出来 最简单的就是  代码如下 复制代码 String strLove = ""; String[] strLoves = (String[])request.getParameterValues("love"); //通过循环读取每个选中项 for (String love : strLoves) {     strLove = strLove + love + ",&quo