私が持っているのは、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();" を試しました チェックボックスのパラメーターでは、それは正しく動作しません。そのため、チェックボックスがちょっとクリックされたときにいつでも送信したいだけです。