提交表单onchange复选框并更新mysql db

时间:2017-04-05 14:57:14

标签: javascript php mysql database onchange

<?php
if(isset($_POST['chkStatus'])){
    for ($i=0;$i<count($_POST['chkStatus']);$i++) {
        $count = count($_POST['chkStatus']);
        list($txtClientId, $txStatusValue) = explode('-', $_POST['chkStatus'][$i], 2);
        $stmtChkStatus=$con->query("SELECT id,status FROM users WHERE id=$txtClientId");
        $SRow = $stmtChkStatus->fetch();
        if($SRow['status']!=$txStatusValue) {
            if($txStatusValue==0) $stmtStatus=$con->query("UPDATE users SET status='0' WHERE id=$txtClientId");
            else $stmtStatus=$con->query("UPDATE users SET status='1' WHERE id=$txtClientId");
        }
    }
}
?>

<html>
    <body>
        <dl>
            <?php $stmtUsers=$con->query("SELECT id,status FROM users");
            while($UsersRow = $stmtUsers->fetch()){
                echo "<dt>$UsersRow[name]</dt>
                <dd><input type='checkbox' name='chkStatus[]' value='$UsersRow[id]-$UsersRow[status]'";
                if($CRow['status']==0) echo " checked";
                echo " onchange='this.form.submit()'>
                </dd>";
            ?>
        </dl>
    </body>
</html>

我的代码的问题是它只执行选中的复选框。我需要一个代码来更改我单击(onchange)的复选框的SQL DB中的状态。

2 个答案:

答案 0 :(得分:0)

您可以使用$_POST['chkStatus']获取所有可能的值并循环显示这些值,而不是循环遍历$con->query("SELECT id,status FROM users")。如果为相应值设置$_POST['chkStatus'],则可以检查。

答案 1 :(得分:0)

您可以将所有复选框值发送到服务器。您可以只发送感兴趣的值。快速而肮脏的解决方案:

  1. 将您的复选框拆分为单独的表单,并仅提交您需要的表单:

    while($UsersRow = $stmtUsers->fetch()){
            echo "<dt>$UsersRow[name]</dt>
       <form .... >  <!-- Here required attributes  -->
            <dd><input type='checkbox' name='chkStatus[]' value='$UsersRow[id]-$UsersRow[status]'";
            if($CRow['status']==0) echo " checked";
            echo " onchange='this.form.submit()'>
       </form>
            </dd>";
    
  2. inclick属性中,选中ID或复选框名称并添加到请求中。