zoukankan      html  css  js  c++  java
  • jquery下php与ajax的数据交换方式

    参考链接: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+="
    ";
                 }
                 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+="
    ";
                 }
                 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);
     ?>

    显示效果如下图:

  • 相关阅读:
    TinyDBF-用200行的DBF解析器来展示良好架构设计
    如何让程序员更容易的开发Web界面?重构SmartAdmin展示TinyUI
    Linux下搭建Tiny开发环境
    《自己动手写框架7》:关于框架体系与战术的思考
    Velocity宏定义的坑与解决办法
    Tiny Formater
    Web前端开发规范
    笔记:2016-6-17
    笔记:2016-6-13
    笔记:2016-06-12
  • 原文地址:https://www.cnblogs.com/fengting/p/4201252.html
Copyright © 2011-2022 走看看