A-A+

Jquery下Ajax与PHP数据交换

2016年03月01日 jquery 暂无评论 阅读 181 次

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

Javascript代码:

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

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

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

  1. PHP:header('Content-Type:text/html;charset=GB2312');
  2.                      $(function(){
  3.      var my_data="前台变量";
  4.      my_data=escape(my_data)+"";//编码,防止汉字乱码
  5.      $.ajax({
  6.          url: "ajax_php.php",
  7.          type: "POST",
  8.          data:{trans_data:my_data},
  9.          //dataType: "json",
  10.          error: function(){
  11.              alert('Error loading XML document');
  12.          },
  13.          success: function(data,status){//如果调用php成功    
  14.              alert(unescape(data));//解码,显示汉字
  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.   <?php
  2.  header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码
  3.  //读取第一个数组
  4.  $backValue="trans_data:";
  5.  $trans=$_POST['trans_data'];
  6.  foreach($trans as $value)
  7.  {
  8.      $backValue=$backValue." ".$value;
  9. }
  10. //读取第二个数组
  11. $backValue=$backValue." , trans_data1:";
  12. $trans=$_POST['trans_data1'];
  13. foreach($trans as $value)
  14. {
  15.     $backValue=$backValue." ".$value;
  16. }
  17. echo $backValue;

PHP代码:

  1. <?php
  2.    header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码
  3.    //读取第一个数组
  4.    $backValue="trans_data:";
  5.    $trans=$_POST['trans_data'];
  6.    foreach($trans as $value)
  7.    {
  8.        $backValue=$backValue." ".$value;
  9.   }
  10.   //读取第二个数组
  11.   $backValue=$backValue." , trans_data1:";
  12.   $trans=$_POST['trans_data1'];
  13.   foreach($trans as $value)
  14.   {
  15.       $backValue=$backValue." ".$value;
  16.   }
  17.   echo $backValue;

显示效果如下图:

\

三、前台传递多个一维数组,后台返回二维数组(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.     my_data1[0]=10;
  8.     my_data1[1]=11;
  9.     my_data1[2]=12;
  10.     $.ajax({
  11.         url: "ajax_php.php",
  12.         type: "POST",
  13.         data:{trans_data:my_data,trans_data1:my_data1},
  14.         dataType: "json",
  15.         error: function(){
  16.             alert('Error loading XML document');
  17.         },
  18.         success: function(data){//如果调用php成功            
  19.             var back="";
  20.             for(var i=0;i<(data.length);i++){
  21.                 for(var j=0;j<data[0].length;j++){
  22.                     back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";
  23.                 }
  24.                 back+="\n";
  25.             }
  26.             alert(back);
  27.         }
  28.     });
  29. });

PHP代码:

显示效果如下图:

\

四、前台传递一维数组和二维数组,后台返回二维数组(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);
 ?>

显示效果如下图:

\

原文地址:

一、前台传递字符串变量,后台返回字符串变量(非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格式,在本文的后面会详细介绍。

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代码:

  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.     my_data1[0]=10;
  8.     my_data1[1]=11;
  9.     my_data1[2]=12;
  10.     $.ajax({
  11.         url: "ajax_php.php",
  12.         type: "POST",
  13.         data:{trans_data:my_data,trans_data1:my_data1},
  14.         dataType: "json",
  15.         error: function(){
  16.             alert('Error loading XML document');
  17.         },
  18.         success: function(data){//如果调用php成功            
  19.             var back="";
  20.             for(var i=0;i<(data.length);i++){
  21.                 for(var j=0;j<data[0].length;j++){
  22.                     back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";
  23.                 }
  24.                 back+="\n";
  25.             }
  26.             alert(back);
  27.         }
  28.     });
  29. });
  30. HP代码:
  31.                  <?php
  32.     header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码    
  33.     $backValue=array();
  34.     $backValue[0]=$_POST['trans_data'];
  35.     $backValue[1]=$_POST['trans_data1'];
  36.     echo json_encode($backValue);
  37. ?>

显示效果如下图:

\

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

Javascript代码:

  1. Javascript代码:
  2. $(function(){
  3. var my_data=new Array();
  4. var my_data1=new Array();
  5. var my_data2=new Array();
  6. my_data[0]=0;
  7. my_data[1]=1;
  8. my_data[2]=2;
  9. my_data1[0]=10;
  10. my_data1[1]=11;
  11. my_data1[2]=12;
  12. my_data2[0]=my_data;
  13. my_data2[1]=my_data1;
  14. $.ajax({
  15. url: "ajax_php.php",
  16. type: "POST",
  17. data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2},
  18. dataType: "json",
  19. error: function(){
  20. alert('Error loading XML document');
  21. },
  22. success: function(data){//如果调用php成功
  23. var back="";
  24. for(var i=0;i<(data.length);i++){
  25. for(var j=0;j<data[0].length;j++){
  26. back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";
  27. }
  28. back+="\n";
  29. }
  30. alert(back);
  31. }
  32. });
  33. });

PHP代码:

显示效果如下图:

\

 原文地址:http://jcyzone.iteye.com/blog/1733668
ps2:

直接贴代码:

  1. <html>
  2. <title>php+jquery+ajax+json简单小例子</title>
  3. <?php
  4. header("Content-Type:text/html;charset=utf-8");
  5. ?>
  6. <head>
  7. <script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
  8. <script type="text/javascript">
  9. $(function() {
  10. $("#subbtn").click(function() {
  11. var params = $("input").serialize();
  12. var url = "1.php";
  13. $.ajax({
  14. type: "post",
  15. url: url,
  16. dataType: "json",
  17. data: params,
  18. success: function(msg){
  19. var backdata = "您提交的姓名为:" + msg.name +
  20. "<br /> 您提交的密码为:" + msg.password;
  21. $("#backdata").html(backdata);
  22. $("#backdata").css({color: "green"});
  23. }
  24. });
  25. });
  26. });
  27. </script>
  28. </head>
  29. <body>
  30. <p><label for="name">姓名:</label>
  31. <input id="name" name="name" type="text" />
  32. </p>
  33. <p><label for="password">密码:</label>
  34. <input id="password" name="password" type="password" />
  35. </p>
  36. <span id="backdata"></span>
  37. <p><input id="subbtn" type="button" value="提交数据" /></p>
  38. </body>
  39. </html>

1.php代码:

 <?php
  1. echo json_encode($_POST);
  2. ?>
标签:

给我留言

Copyright © web前端技术开发个人博客 保留所有权利  京ICP备14060653号 Theme  Ality

用户登录