PHP接收多個(gè)同名復(fù)選框信息不像ASP那樣自動(dòng)轉(zhuǎn)換成為數(shù)組,這給使用帶來(lái)了一定不便,但是還是有解決辦法的,就是利用javascript做一下預(yù)處理,多個(gè)同名復(fù)選框在javascript中還是以數(shù)組的形式存在的,所以在表單提交之前可以利用javascript把復(fù)選框中的信息組合成一個(gè)字符數(shù)組賦值給表單中的隱藏元素,然后用PHP中的explode函數(shù)解析此數(shù)組,這樣就可以實(shí)現(xiàn)復(fù)選框信息的傳遞了,下面舉例說(shuō)明。
假設(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>
$items = explode(" ", $HTTP_POST_VARS["items"]);
就可以把這些選項(xiàng)分離出來(lái)成為數(shù)組。需要注重的是選項(xiàng)中的value不能包含分割符(這里是空格).
新聞熱點(diǎn)
疑難解答