eecdc 发表于 2015-8-23 11:09:10

Jquery框架下Ajax与PHP数据交换

  最近刚刚做了一个小项目,其中用到了大量的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;
5   my_data=1;
6   my_data=2;
7   
8   my_data1=10;
9   my_data1=11;
10   my_data1=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;
5   my_data=1;
6   my_data=2;
7   
8   my_data1=10;
9   my_data1=11;
10   my_data1=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.length;j++){
24                     back+=" "+i+" 行 "+j+" 列 :"+data+" ";
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=$_POST['trans_data'];   
5   $backValue=$_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;
7   my_data=1;
8   my_data=2;
9   
10   my_data1=10;
11   my_data1=11;
12   my_data1=12;
13   
14   my_data2=my_data;
15   my_data2=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.length;j++){
29                     back+=" "+i+" 行 "+j+" 列 :"+data+" ";
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=$_POST['trans_data'];   
6   $backValue=$_POST['trans_data1'];
7   
8   echo json_encode($backValue);
9 ?>
  显示效果如下图:
页: [1]
查看完整版本: Jquery框架下Ajax与PHP数据交换