最近剛剛做了一個小項目,其中用到了大量的Ajax技術。當然了,剛開始用的時候,避免不了出現很多的錯誤,也走了汗多彎路,這里整理了出來,除了是為了供自己以后開發參考外,也是為了拿出來與大家分享,希望能讓初學者少走彎路,也希望能夠得到高手的批評與指正。
一、前台傳遞字符串變量,后台返回字符串變量(非json格式)
Javascript代碼:
這里,為了解決Ajax數據傳遞出現的漢字亂碼,在字符串傳遞之前,使用javascript函數escape()對漢字字符串進行了編碼,並且對返回
的字符串使用unescape()函數進行解碼,使得漢字得以正常顯示。當然了,后台PHP代碼也添加了頭文件,以保證漢字字符串不會出現亂碼。各種后台代碼解決
漢字亂碼問題的方式如下:
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");
1 $(function(){ 2 var my_data="前台變量"; 3 my_data=escape(my_data)+"";//編碼,防止漢字亂碼 4 $.ajax({ 5 url: "ajax_php.php", 6 type: "POST", 7 data:{trans_data:my_data}, 8 //dataType: "json", 9 error: function(){ 10 alert('Error loading XML document'); 11 }, 12 success: function(data,status){//如果調用php成功 13 alert(unescape(data));//解碼,顯示漢字 14 } 15 }); 16 17 });
PHP代碼:
1 <?php 2 header('Content-Type:text/html; charset=gb2312');//使用gb2312編碼,使中文不會變成亂碼 3 $backValue=$_POST['trans_data']; 4 echo $backValue."+后台返回"; 5 ?>
顯示效果如下圖所示:
二、前台傳遞多個一維數組,后台返回字符串變量(非json格式)
Javascript代碼:
在非json格式下,后台只能返回字符串,如果想后台返回數組,可以采用json格式,在本文的后面會詳細介紹。
1 $(function(){ 2 var my_data=new Array(); 3 var my_data1=new Array(); 4 my_data[0]=0; 5 my_data[1]=1; 6 my_data[2]=2; 7 8 my_data1[0]=10; 9 my_data1[1]=11; 10 my_data1[2]=12; 11 12 $.ajax({ 13 url: "ajax_php.php", 14 type: "POST", 15 data:{trans_data:my_data,trans_data1:my_data1}, 16 //dataType: "json", 17 error: function(){ 18 alert('Error loading XML document'); 19 }, 20 success: function(data,status){//如果調用php成功 21 alert(data); 22 } 23 }); 24 25 });
PHP代碼:
1 <?php 2 header('Content-Type:text/html; charset=gb2312');//使用gb2312編碼,使中文不會變成亂碼 3 4 //讀取第一個數組 5 $backValue="trans_data:"; 6 $trans=$_POST['trans_data']; 7 foreach($trans as $value) 8 { 9 $backValue=$backValue." ".$value; 10 } 11 12 //讀取第二個數組 13 $backValue=$backValue." , trans_data1:"; 14 $trans=$_POST['trans_data1']; 15 foreach($trans as $value) 16 { 17 $backValue=$backValue." ".$value; 18 } 19 echo $backValue; 20 ?>
顯示效果如下圖:
三、前台傳遞多個一維數組,后台返回二維數組(json格式)
Javascript代碼:
1 $(function(){ 2 var my_data=new Array(); 3 var my_data1=new Array(); 4 my_data[0]=0; 5 my_data[1]=1; 6 my_data[2]=2; 7 8 my_data1[0]=10; 9 my_data1[1]=11; 10 my_data1[2]=12; 11 12 $.ajax({ 13 url: "ajax_php.php", 14 type: "POST", 15 data:{trans_data:my_data,trans_data1:my_data1}, 16 dataType: "json", 17 error: function(){ 18 alert('Error loading XML document'); 19 }, 20 success: function(data){//如果調用php成功 21 var back=""; 22 for(var i=0;i<(data.length);i++){ 23 for(var j=0;j<data[0].length;j++){ 24 back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "; 25 } 26 back+="\n"; 27 } 28 alert(back); 29 } 30 }); 31 32 });
PHP代碼:
1 <?php 2 header('Content-Type:text/html; charset=gb2312');//使用gb2312編碼,使中文不會變成亂碼 3 $backValue=array(); 4 $backValue[0]=$_POST['trans_data']; 5 $backValue[1]=$_POST['trans_data1']; 6 7 echo json_encode($backValue); 8 ?>
顯示效果如下圖:
四、前台傳遞一維數組和二維數組,后台返回二維數組(json格式)
Javascript代碼:
1 $(function(){ 2 var my_data=new Array(); 3 var my_data1=new Array(); 4 var my_data2=new Array(); 5 6 my_data[0]=0; 7 my_data[1]=1; 8 my_data[2]=2; 9 10 my_data1[0]=10; 11 my_data1[1]=11; 12 my_data1[2]=12; 13 14 my_data2[0]=my_data; 15 my_data2[1]=my_data1; 16 17 $.ajax({ 18 url: "ajax_php.php", 19 type: "POST", 20 data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2}, 21 dataType: "json", 22 error: function(){ 23 alert('Error loading XML document'); 24 }, 25 success: function(data){//如果調用php成功 26 var back=""; 27 for(var i=0;i<(data.length);i++){ 28 for(var j=0;j<data[0].length;j++){ 29 back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" "; 30 } 31 back+="\n"; 32 } 33 alert(back); 34 } 35 }); 36 37 });
PHP代碼:
1 <?php 2 header('Content-Type:text/html; charset=gb2312');//使用gb2312編碼,使中文不會變成亂碼 3 $backValue=array(); 4 $backValue=$_POST['trans_data2']; 5 $backValue[2]=$_POST['trans_data']; 6 $backValue[3]=$_POST['trans_data1']; 7 8 echo json_encode($backValue); 9 ?>
顯示效果如下圖: