PHP中接收復(fù)選框信息的方法
[日期:2005-06-28] 來源:學(xué)習(xí)筆記 作者:流浪的風(fēng) [字體:大 中 小] PHP接收多個(gè)同名復(fù)選框信息不像ASP那樣自動(dòng)轉(zhuǎn)換成為數(shù)組,這給使用帶來了一定不便。但是還
是有解決辦法的,就是利用javascript做一下預(yù)處理。多個(gè)同名復(fù)選框在javascript中還是以數(shù)組的 形式存在的,所以在表單提交之前可以利用javascript把復(fù)選框中的信息組合成一個(gè)字符數(shù)組賦值給 表單中的隱藏元素,然后用PHP中的explode函數(shù)解析此數(shù)組,這樣就可以實(shí)現(xiàn)復(fù)選框信息的傳遞了。 下面舉例說明。 假設(shè)有這樣一個(gè)表單: <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>
這個(gè)表單有四個(gè)名字都是item的復(fù)選框,當(dāng)用戶單擊Submit按鈕的時(shí)候,Checker函數(shù)會(huì)被調(diào)用,并且
如果Checker返回true表單就被提交,返回false表單就不會(huì)被提交。這里Checker函數(shù)就是我們要編寫 的預(yù)處理函數(shù)。在HTML的header部分添加下面的javascript: <script language="javascript">
<!-- function Checker() { form1.items.value = ""; if ( !form1.item.length ) // 只有一個(gè)復(fù)選框,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 ) // 復(fù)選框中有選中的框 { 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> 這樣就可以把所有選中的復(fù)選框的value組合成為一個(gè)字符串?dāng)?shù)組,在myphp.php使用這樣的語句:
$items = explode(" ", $HTTP_POST_VARS["items"]);
就可以把這些選項(xiàng)分離出來成為數(shù)組。需要注意的是選項(xiàng)中的value不能包含分割符(這里是空格)。
本文來自CSDN博客,轉(zhuǎn)載請(qǐng)標(biāo)明出處:http://blog.csdn.net/webdesman/archive/2008/07/22/2689176.aspx
|
|