PHP開發(fā)中接收復(fù)選框信息的方法
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' 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使用這樣的語(yǔ)句:
$items = explode(' ', $HTTP_POST_VARS['items'])
就可以把這些選項(xiàng)分離出來成為數(shù)組。需要注意的是選項(xiàng)中的value不能包含分割符(這里是空格)。
