Jquery框架下Ajax与PHP数据交换
最近刚刚做了一个小项目,其中用到了大量的Ajax技术。当然了,刚开始用的时候,避免不了出现很多的错误,也走了汗多弯路,这里整理了出来,除了是为了供自己以后开发参考外,也是为了拿出来与大家分享,希望能让初学者少走弯路,也希望能够得到高手的批评与指正。一、前台传递字符串变量,后台返回字符串变量(非json格式)
Javascript代码:
这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对返回
的字符串使用unescape()函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决
汉字乱码问题的方式如下:
PHP:header('Content-Type:text/html;charset=GB2312');
ASP:Response.Charset("GB2312")
JSP:response.setHeader("Charset","GB2312");
1 $(function(){
2 var my_data="前台变量";
3 my_data=escape(my_data)+"";//编码,防止汉字乱码
4 $.ajax({
5 url: "ajax_php.php",
6 type: "POST",
7 data:{trans_data:my_data},
8 //dataType: "json",
9 error: function(){
10 alert('Error loading XML document');
11 },
12 success: function(data,status){//如果调用php成功
13 alert(unescape(data));//解码,显示汉字
14 }
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 $(function(){
2 var my_data=new Array();
3 var my_data1=new Array();
4 my_data=0;
5 my_data=1;
6 my_data=2;
7
8 my_data1=10;
9 my_data1=11;
10 my_data1=12;
11
12 $.ajax({
13 url: "ajax_php.php",
14 type: "POST",
15 data:{trans_data:my_data,trans_data1:my_data1},
16 //dataType: "json",
17 error: function(){
18 alert('Error loading XML document');
19 },
20 success: function(data,status){//如果调用php成功
21 alert(data);
22 }
23 });
24
25 });
PHP代码:
1 <?php
2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码
3
4 //读取第一个数组
5 $backValue="trans_data:";
6 $trans=$_POST['trans_data'];
7 foreach($trans as $value)
8 {
9 $backValue=$backValue." ".$value;
10 }
11
12 //读取第二个数组
13 $backValue=$backValue." , trans_data1:";
14 $trans=$_POST['trans_data1'];
15 foreach($trans as $value)
16 {
17 $backValue=$backValue." ".$value;
18 }
19 echo $backValue;
20 ?>
显示效果如下图:
三、前台传递多个一维数组,后台返回二维数组(json格式)
Javascript代码:
1 $(function(){
2 var my_data=new Array();
3 var my_data1=new Array();
4 my_data=0;
5 my_data=1;
6 my_data=2;
7
8 my_data1=10;
9 my_data1=11;
10 my_data1=12;
11
12 $.ajax({
13 url: "ajax_php.php",
14 type: "POST",
15 data:{trans_data:my_data,trans_data1:my_data1},
16 dataType: "json",
17 error: function(){
18 alert('Error loading XML document');
19 },
20 success: function(data){//如果调用php成功
21 var back="";
22 for(var i=0;i<(data.length);i++){
23 for(var j=0;j<data.length;j++){
24 back+=" "+i+" 行 "+j+" 列 :"+data+" ";
25 }
26 back+="\n";
27 }
28 alert(back);
29 }
30 });
31
32 });
PHP代码:
1 <?php
2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码
3 $backValue=array();
4 $backValue=$_POST['trans_data'];
5 $backValue=$_POST['trans_data1'];
6
7 echo json_encode($backValue);
8 ?>
显示效果如下图:
四、前台传递一维数组和二维数组,后台返回二维数组(json格式)
Javascript代码:
1 $(function(){
2 var my_data=new Array();
3 var my_data1=new Array();
4 var my_data2=new Array();
5
6 my_data=0;
7 my_data=1;
8 my_data=2;
9
10 my_data1=10;
11 my_data1=11;
12 my_data1=12;
13
14 my_data2=my_data;
15 my_data2=my_data1;
16
17 $.ajax({
18 url: "ajax_php.php",
19 type: "POST",
20 data:{trans_data:my_data,trans_data1:my_data1,trans_data2:my_data2},
21 dataType: "json",
22 error: function(){
23 alert('Error loading XML document');
24 },
25 success: function(data){//如果调用php成功
26 var back="";
27 for(var i=0;i<(data.length);i++){
28 for(var j=0;j<data.length;j++){
29 back+=" "+i+" 行 "+j+" 列 :"+data+" ";
30 }
31 back+="\n";
32 }
33 alert(back);
34 }
35 });
36
37 });
PHP代码:
1 <?php
2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码
3 $backValue=array();
4 $backValue=$_POST['trans_data2'];
5 $backValue=$_POST['trans_data'];
6 $backValue=$_POST['trans_data1'];
7
8 echo json_encode($backValue);
9 ?>
显示效果如下图:
页:
[1]