前端技术   

Jquery框架下Ajax与PHP数据交换

时间:2013-01-21 17:02:00

一、前台传递字符串变量,后台返回字符串变量(非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 ?>
复制代码

显示效果如下图:



原文出处:maplecumt

 

来源:PHPchina

上一篇:周鸿祎: 很多人盼着我倒下 2013-01-24

下一篇:PHP 数组、关联数组 2013-01-21

Notice: Constant RUNTIME already defined in /srv/html/srccn/news/config.php on line 15 Notice: Constant ROOTDIR already defined in /srv/html/srccn/news/config.php on line 16 Notice: Constant SITEDIR already defined in /srv/html/srccn/news/config.php on line 17 Notice: Constant DATAURL already defined in /srv/html/srccn/news/config.php on line 20 Notice: Constant VERSION already defined in /srv/html/srccn/news/system/kernel.php on line 17 Notice: Constant COREDIR already defined in /srv/html/srccn/news/system/kernel.php on line 18 Fatal error: require(): Cannot redeclare class mysql in /srv/html/srccn/news/system/kernel.php on line 22