如何用Ajax傳一個數組數據


PHP接收多個同名復選框信息不像ASP那樣自動轉換成為數組,這給使用帶來了一定不便。但是還是有解決辦法的,就是利用javascript做一下預處 理。多個同名復選框在javascript中還是以數組的形式存在的,所以在表單提交之前可以利用javascript把復選框中的信息組合成一個字符數 組賦值給表單中的隱藏元素,然后用PHP中的explode函數解析此數組,這樣就可以實現復選框信息的傳遞了。下面舉例說明。

假設有這樣一個表單:

<form name="form1" id="form1" method="post" action="http://www.nowamagic.net/index.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:

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; 
} 

這樣就可以把所有選中的復選框的value組合成為一個字符串數組,在myphp.php使用這樣的語句:

$items = explode(" ", $HTTP_POST_VARS["items"]);  

就可以把這些選項分離出來成為數組。需要注意的是選項中的value不能包含分割符(這里是空格)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM