Jquery下Ajax与PHP数据交换

来源:互联网 发布:2015珠三角gdp数据 编辑:程序博客网 时间:2024/06/05 20:43

http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2013/0122/11971.html

一、前台传递字符串变量,后台返回字符串变量(非json格式)

  Javascript代码:

  这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对返回

的字符串使用unescape()函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决

汉字乱码问题的方式如下:

  PHP:header('Content-Type:text/html;charset=GB2312'); 

 

 $(function(){     var my_data="前台变量";     my_data=escape(my_data)+"";//编码,防止汉字乱码     $.ajax({         url: "ajax_php.php",           type: "POST",         data:{trans_data:my_data},         //dataType: "json",         error: function(){               alert('Error loading XML document');           },           success: function(data,status){//如果调用php成功                 alert(unescape(data));//解码,显示汉字         }     });      });

  PHP代码:

 <?php     header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码     $backValue=$_POST['trans_data'];     echo $backValue."+后台返回"; ?>

显示效果如下图所示:

                                                     \

 

二、前台传递多个一维数组,后台返回字符串变量(非json格式)

  Javascript代码:

  在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。

 $(function(){     var my_data=new Array();     var my_data1=new Array();     my_data[0]=0;     my_data[1]=1;     my_data[2]=2;          my_data1[0]=10;     my_data1[1]=11;     my_data1[2]=12;          $.ajax({         url: "ajax_php.php",           type: "POST",         data:{trans_data:my_data,trans_data1:my_data1},         //dataType: "json",         error: function(){               alert('Error loading XML document');           },           success: function(data,status){//如果调用php成功                 alert(data);         }     });      });

  PHP代码:

  <?php      header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码            //读取第一个数组      $backValue="trans_data:";      $trans=$_POST['trans_data'];      foreach($trans as $value)      {          $backValue=$backValue." ".$value;     }          //读取第二个数组     $backValue=$backValue." , trans_data1:";     $trans=$_POST['trans_data1'];     foreach($trans as $value)     {         $backValue=$backValue." ".$value;     }     echo $backValue; ?>

显示效果如下图:

\

 

三、前台传递多个一维数组,后台返回二维数组(json格式)

  Javascript代码:

  $(function(){     var my_data=new Array();     var my_data1=new Array();     my_data[0]=0;     my_data[1]=1;     my_data[2]=2;           my_data1[0]=10;     my_data1[1]=11;     my_data1[2]=12;          $.ajax({         url: "ajax_php.php",           type: "POST",         data:{trans_data:my_data,trans_data1:my_data1},         dataType: "json",         error: function(){               alert('Error loading XML document');           },           success: function(data){//如果调用php成功                         var back="";             for(var i=0;i<(data.length);i++){                 for(var j=0;j<data[0].length;j++){                     back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";                 }                 back+="\n";             }             alert(back);         }     }); });

  PHP代码:

 <?php     header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码         $backValue=array();     $backValue[0]=$_POST['trans_data'];         $backValue[1]=$_POST['trans_data1'];          echo json_encode($backValue); ?>

显示效果如下图:

\

四、前台传递一维数组和二维数组,后台返回二维数组(json格式)

  Javascript代码:

 $(function(){     var my_data=new Array();     var my_data1=new Array();     var my_data2=new Array();           my_data[0]=0;     my_data[1]=1;     my_data[2]=2;          my_data1[0]=10;     my_data1[1]=11;     my_data1[2]=12;          my_data2[0]=my_data;     my_data2[1]=my_data1;          $.ajax({         url: "ajax_php.php",           type: "POST",         data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2},         dataType: "json",         error: function(){               alert('Error loading XML document');           },           success: function(data){//如果调用php成功                         var back="";             for(var i=0;i<(data.length);i++){                 for(var j=0;j<data[0].length;j++){                     back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";                 }                 back+="\n";             }             alert(back);         }     });     });

  PHP代码:

 <?php     header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码         $backValue=array();     $backValue=$_POST['trans_data2'];         $backValue[2]=$_POST['trans_data'];         $backValue[3]=$_POST['trans_data1'];          echo json_encode($backValue); ?>

显示效果如下图:

\


0 0
原创粉丝点击