程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP中獲得復選框是否選中並寫入數據庫

PHP中獲得復選框是否選中並寫入數據庫

編輯:關於PHP編程

下面我們總結了關於PHP中獲得復選框是否選中並寫入數據庫 有需要學習的朋友可參考參考。

form.html

 代碼如下 復制代碼 <form action=checkbox.php method=post>
<input name="s[]" type="checkbox" value="3" />3<br>
<input name="s[]" type="checkbox" value="7" />7<br>
<input name="s[]" type="checkbox" value="1" />1<br>
<input name="s[]" type="checkbox" value="15" />15<br>
<input type=submit>
</form>

然後建立一個處理表單的程序:
checkbox.php

 代碼如下 復制代碼

<?php 
$a=$_POST["s"];
print_r($a);
?>

但是上面這個程序只是用來顯示復選框是否正常,如果逐個取出數組中所有的數據,需要用到循環。

所以進一步將程序修改為:
checkbox.php

 代碼如下 復制代碼

<?php 
$a=$_POST["s"];
for($i=0;$i<count($a);$i++)
{
echo "選項".$a[$i]."被選中<br />";
}
?>

這樣執行的結果類似於:
選項3被選中
選項15被選中

利用javascript做一下預處理。多個同名復選框在javascript中還是以數組的形式存在的,所以在表單提交之前可以利用javascript把復選框中的信息組合成一個字符數組賦值給表單中的隱藏元素,然後用php中的explode函數解析此數組,這樣就可以實現復選框信息的傳遞了。下面舉例說明。
假設有這樣一個表單:

 代碼如下 復制代碼

<form name="form1" id="form1" method="post" action="myphp.php" onsubmit="return checker()">

<input type="checkbox" name="item" value="1">1<br>

<input type="checkbox" name="item" value="2">2<br>

<input type="checkbox" name="item" value="3">3<br>

<input type="checkbox" name="item" value="4">4<br>

<input type="hidden" name="items" value="">

<input type="submit" value="submit">

</form>

這個表單有四個名字都是item的復選框,當用戶單擊submit按鈕的時候,checker函數會被調用,並且如果checker返回true表單就被提交,返回false表單就不會被提交。這裡checker函數就是我們要編寫的預處理函數。在html的header部分添加下面的javascript:

 代碼如下 復制代碼

<script language="javascript">
<!--
function checker()
{
form1.items.value = "";
if ( !form1.item.length ) // 只有一個復選框,form1.item.length = undefined
{
if ( form1.items.checked )
form1.items.value = form1.item.value;
}
else
{
for ( i = 0 ; i < form1.item.length ; i++ )
{
if ( form1.item(i).checked ) // 復選框中有選中的框
{
form1.items.value = form1.item(i).value;
for ( j = i + 1 ; j < form1.item.length ; j++ )
{
if ( form1.item(j).checked )
{
form1.items.value += " "; //用空格做分割符
form1.items.value += form1.item(j).value;
}
}
break;
}
}
}
return true;
}
-->
</script>

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved