Jquery下Ajax与PHP数据交换

本文通过四个具体案例展示了如何利用Ajax与PHP进行数据交互。包括解决汉字乱码问题的方法、不同数据类型的传递与接收方式,以及如何使用JSON格式进行更复杂的数据交换。


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

显示效果如下图:

\

 
id="iframe168229_0" src="http://pos.baidu.com/tccm?rtbid=2053463&rdid=9223372032564345876&dc=2&di=168229&dri=0&dis=0&dai=1&ps=6971x215&dcb=BAIDU_SSP_define&dtm=HTML_POST&dvi=0.0&dci=-1&dpt=none&tsr=0&tpr=1475898506934&ti=Jquery%E4%B8%8BAjax%E4%B8%8EPHP%E6%95%B0%E6%8D%AE%E4%BA%A4%E6%8D%A2&ari=2&dbv=2&drs=1&pcs=1349x579&pss=1349x6986&cfv=0&cpl=40&chi=1&cce=true&cec=GBK&tlm=1453018578&rw=579&ltu=http%3A%2F%2Fwww.php100.com%2Fhtml%2Fwebkaifa%2FPHP%2FPHPyingyong%2F2013%2F0122%2F11971.html&ltr=https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DCxZpRae9Ne_gYF79Hi9urv4D9HSfjrO-d_HDS7TOvp06OX7Y9FEoSeoWsgMaczpEKAIZpVUL1F36QieQVAxXjC8iysg_Mz-jIg4fGZon5DinR2axvczZ3TG7wVhDuMFL%26wd%3D%26eqid%3Ddd70e72d0000ceb60000000257f86c66&lcr=https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DCxZpRae9Ne_gYF79Hi9urv4D9HSfjrO-d_HDS7TOvp06OX7Y9FEoSeoWsgMaczpEKAIZpVUL1F36QieQVAxXjC8iysg_Mz-jIg4fGZon5DinR2axvczZ3TG7wVhDuMFL%26wd%3D%26eqid%3Ddd70e72d0000ceb60000000257f86c66&ecd=1&psr=1366x768&par=1366x728&pis=-1x-1&ccd=24&cja=true&cmi=66&col=zh-CN&cdo=-1&tcn=1475898507&qn=e05dd2c21cc98402&tt=1475898506205.741.1285.1289" width="468" height="60" align="center,center" vspace="0" hspace="0" marginwidth="0" marginheight="0" scrolling="no" frameborder="0" allowtransparency="true" style="padding: 0px; margin: 0px; border-width: 0px; border-style: initial; vertical-align: bottom;">

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

显示效果如下图:

\

 
id="iframe168229_0" src="http://pos.baidu.com/tccm?rtbid=2053463&rdid=9223372032564345876&dc=2&di=168229&dri=0&dis=0&dai=1&ps=6971x215&dcb=BAIDU_SSP_define&dtm=HTML_POST&dvi=0.0&dci=-1&dpt=none&tsr=0&tpr=1475898506934&ti=Jquery%E4%B8%8BAjax%E4%B8%8EPHP%E6%95%B0%E6%8D%AE%E4%BA%A4%E6%8D%A2&ari=2&dbv=2&drs=1&pcs=1349x579&pss=1349x6986&cfv=0&cpl=40&chi=1&cce=true&cec=GBK&tlm=1453018578&rw=579&ltu=http%3A%2F%2Fwww.php100.com%2Fhtml%2Fwebkaifa%2FPHP%2FPHPyingyong%2F2013%2F0122%2F11971.html&ltr=https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DCxZpRae9Ne_gYF79Hi9urv4D9HSfjrO-d_HDS7TOvp06OX7Y9FEoSeoWsgMaczpEKAIZpVUL1F36QieQVAxXjC8iysg_Mz-jIg4fGZon5DinR2axvczZ3TG7wVhDuMFL%26wd%3D%26eqid%3Ddd70e72d0000ceb60000000257f86c66&lcr=https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DCxZpRae9Ne_gYF79Hi9urv4D9HSfjrO-d_HDS7TOvp06OX7Y9FEoSeoWsgMaczpEKAIZpVUL1F36QieQVAxXjC8iysg_Mz-jIg4fGZon5DinR2axvczZ3TG7wVhDuMFL%26wd%3D%26eqid%3Ddd70e72d0000ceb60000000257f86c66&ecd=1&psr=1366x768&par=1366x728&pis=-1x-1&ccd=24&cja=true&cmi=66&col=zh-CN&cdo=-1&tcn=1475898507&qn=e05dd2c21cc98402&tt=1475898506205.741.1285.1289" width="468" height="60" align="center,center" vspace="0" hspace="0" marginwidth="0" marginheight="0" scrolling="no" frameborder="0" allowtransparency="true" style="padding: 0px; margin: 0px; border-width: 0px; border-style: initial; vertical-align: bottom;">
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值