JQuery下Ajax与PHP数据交换

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

HTML代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<script type="text/javascript" src="jquery-1.4.min.js"></script>
<script type="text/javascript" src="ajax.js"></script>
<title>Ajax test</title>
</head>
<body>
<input type="text" name="input" id="input"/><br/>
<input type="submit" name="submit" id="submit"/>
</body>
</html>
JQuery代码:


$(function(){
	$("#submit").click(function(){
		var input=$("#input").val();
		input=escape(input)+"";
		$.ajax({
			type:"POST",
			url:"ajax_test.php",
			data:{"my_input":input},
			error:function(XMLHttpRequest, textStatus, errorThrown){
				alert("false");  
			},
			success:function(data,status){
				alert(unescape(data));
			}
		});
	});
});

PHP代码:





<?php
header('Content-Type:text/html;charset=utf-8'); 
$output=$_POST['my_input'];
echo $output."+后台返回";
?>

PS:1、添加JQuery库的时候个人推荐下载到本地后添加,不建议从网上加载,有可能会因为网络问题而出现"304 not modified"的错误
     2、使用JQuery时,HTML不要用<form>标签,否则即使AJAX发送请求成功后,也返回不了数据。
     3、要先引用JQuery库,后引入js文件,否则没有反应
     4、如果想从后台放回中文字符, php中要加上
header('ContentType:text/html;charset=utf-8'); (gb2312不行,貌似jquery接受的都是utf8编码的字符)

二、前台传递多个一维数组,后台返回字符串变量(非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=utf-8');//使用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);
 ?>

显示效果如下图:

\

 

资料转载于:http://www.php100.com/html/webkaifa/PHP/PHPyingyong/2013/0122/11971.html



 
 




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值