您好,欢迎访问一九零五行业门户网

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 php2 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]=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 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]=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 ?>
显示效果如下图:
四、前台传递一维数组和二维数组,后台返回二维数组(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]=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 ?>
显示效果如下图:
其它类似信息

推荐信息