0

私が持っているのは、mySQL データベースからのアイテムの配列で、各アイテムにはチェックボックスがあります。チェックボックスをクリックすると、チェックまたはチェック解除されたアイテムの情報がデータベースに送信されるようにしようとしています。チェックされていない= 1とチェックされている= 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();" を試しました チェックボックスのパラメーターでは、それは正しく動作しません。そのため、チェックボックスがちょっとクリックされたときにいつでも送信したいだけです。

4

2 に答える 2

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
        }
    });
});
于 2012-04-19T20:11:43.033 に答える
0

document.getElementById('form1').submit()チェックボックスのonchangeメソッドで試してください

于 2012-04-19T19:22:46.573 に答える