jquery下ajax与php数据交换,Jquery框架下Ajax与PHP数据交换

本文详细介绍了在JavaScript中使用Ajax技术时遇到的汉字乱码问题及其解决方案,包括前台传递字符串、一维数组到后台并接收返回的字符串。通过使用escape()和unescape()函数处理汉字编码,确保在PHP、ASP、JSP等后台中正确显示。同时,展示了如何传递和接收多个一维数组,以及如何以JSON格式返回二维数组。内容适合Ajax初学者参考,旨在减少学习过程中的困扰。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近刚刚做了一个小项目,其中用到了大量的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 php2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码

3 $backValue=$_POST['trans_data'];4 echo $backValue."+后台返回";5 ?>

显示效果如下图所示:

2012102015405163.png

二、前台传递多个一维数组,后台返回字符串变量(非json格式)

Javascript代码:

在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。

1 $(function(){2 var my_data=newArray();3 var my_data1=newArray();4 my_data[0]=0;5 my_data[1]=1;6 my_data[2]=2;7

8 my_data1[0]=10;9 my_data1[1]=11;10 my_data1[2]=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 php2 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 ?>

显示效果如下图:

2012102015594863.png

三、前台传递多个一维数组,后台返回二维数组(json格式)

Javascript代码:

1 $(function(){2 var my_data=newArray();3 var my_data1=newArray();4 my_data[0]=0;5 my_data[1]=1;6 my_data[2]=2;7

8 my_data1[0]=10;9 my_data1[1]=11;10 my_data1[2]=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){

23 for(var j=0;j){

24 back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";25 }26 back+="\n";27 }28 alert(back);29 }30 });31

32 });

PHP代码:

1 php2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码

3 $backValue=array();4 $backValue[0]=$_POST['trans_data'];5 $backValue[1]=$_POST['trans_data1'];6

7 echo json_encode($backValue);8 ?>

显示效果如下图:

2012102016191689.png

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

Javascript代码:

1 $(function(){2 var my_data=newArray();3 var my_data1=newArray();4 var my_data2=newArray();5

6 my_data[0]=0;7 my_data[1]=1;8 my_data[2]=2;9

10 my_data1[0]=10;11 my_data1[1]=11;12 my_data1[2]=12;13

14 my_data2[0]=my_data;15 my_data2[1]=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){

28 for(var j=0;j){

29 back+=" "+i+" 行 "+j+" 列 :"+data[i][j]+" ";30 }31 back+="\n";32 }33 alert(back);34 }35 });36

37 });

PHP代码:

1 php2 header('Content-Type:text/html; charset=gb2312');//使用gb2312编码,使中文不会变成乱码

3 $backValue=array();4 $backValue=$_POST['trans_data2'];5 $backValue[2]=$_POST['trans_data'];6 $backValue[3]=$_POST['trans_data1'];7

8 echo json_encode($backValue);9 ?>

显示效果如下图:

2012102016240697.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值