复选框onChange提交表单

时间:2012-04-19 19:14:10

标签: php javascript jquery mysql

我拥有的是mySQL数据库中的一系列项目,每个项目都有一个复选框。我试图这样做,当你点击复选框时,它会将信息提交给数据库,以查看已选中或未选中的项目。我有它unchecked = 1和checked = 0.这是我要显示项目的地方。

现在我的问题是我似乎无法将任何内容提交到我的数据库中,我不明白jQuery足以能够为它编写函数,所以我需要一些帮助。这是我的代码所得到的。

if(isset($_POST['submit'])){
        foreach($_POST['id'] as $id){
            $value = (isset($_POST['location'][$id]) && $_POST['location'][$id]=="0" ? '0' : '1');
            $insert = mysql_query("UPDATE items SET location='$value' WHERE id='$id'") or die('Insert Error: '.mysql_error());
        }
    }
echo '<form id="form1" method="post"><input type="submit" name="submit" value="Submit">';
$result = mysql_query("SELECT * FROM items")
    or die("Query Failed: ".mysql_error());
    $counter = 0;
    echo '<div class="specialcontainer">';
while($row = mysql_fetch_array($result)){
    list($id, $item_info, $item_img, $price, $sale, $location) = $row;
    if($location == '0'){
        $set_checked = ' checked="checked" ';
    }else{
        $set_checked = '';
    }
    if($counter % 5==0) {
        echo '</div>';
        echo '<div class="specialcontainer">';
    }
    echo '<div class="special"><img src="../images/items/'.$item_img.'" width="130" /><br />';
    echo $item_info.'<br />';
    echo 'Reg. $'.$price.'<br />';
    echo 'Sale $'.$sale.'<br />';
    echo 'Slide Show: <input type="checkbox" id="ch" value="0" name="location['.$id.']"'.$set_checked.' /><br />';
    echo '<input type="button" value="Edit" name="edit" onclick="window.location.href=\'specials.php?action=edit&id='.$id.'\'">';
    echo '<input type="button" value="Delete" name="Delete" onclick="window.location.href=\'specials.php?action=delete&id='.$id.'\'">';
    echo '<input type="hidden" name="id[]" value='.$id.' />';
    echo '</div>';
    $counter++;
}
echo '</div>';
echo '<input type="submit" name="submit" value="Submit"></form>';

所以你可以看到,我确实有提交按钮,但我的计划是删除它以进行onChange提交。我试过onchange =“this.form.submit();”在checkbox参数中但它无法正常工作。所以我只想让它随时提交一个复选框点击一下。

2 个答案:

答案 0 :(得分:1)

像这样的Ajax解决方案会起作用吗?

$('ch').click(function() {
    //this is what goes into $_POST
    var data = 'id='+ $(this).attr('name') +'&checked=' + $(this).is(':checked');
    $.ajax({
        //This would be the url that would handle updating the MySQL Record
        url: my_mysql_handler.php,
        cache: false,
        type: 'POST',
        data: data,
        success: function(response) {
            alert(response); //or whatever you want to do with the success/fail notification
        }
    });
});

答案 1 :(得分:0)

您应该在复选框的document.getElementById('form1').submit()方法中尝试onchange