Jquery框架下Ajax与PHP数据交换

来源:互联网 发布:可可网络验证查看 编辑:程序博客网 时间:2024/06/07 18:35
最近刚刚做了一个小项目,其中用到了大量的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 <?php2     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 <?php2     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 <?php2     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 ?>
复制代码

显示效果如下图:

原创粉丝点击