首页 > 代码库 > jquery下php与ajax的数据交换方式
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="http://www.mamicode.com/前台变量"; my_data=http://www.mamicode.com/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=http://www.mamicode.com/$_POST[‘trans_data‘];"+后台返回"; ?>
显示效果如下图所示:
二、前台传递多个一维数组,后台返回字符串变量(非json格式)
Javascript代码:
在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。
$(function(){ var my_data=http://www.mamicode.com/new Array();"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=http://www.mamicode.com/$backValue." ".$value; } //读取第二个数组 $backValue=http://www.mamicode.com/$backValue." , trans_data1:"; $trans=$_POST[‘trans_data1‘]; foreach($trans as $value) { $backValue=http://www.mamicode.com/$backValue." ".$value; } echo $backValue; ?>
显示效果如下图:
三、前台传递多个一维数组,后台返回二维数组(json格式)
Javascript代码:
$(function(){ var my_data=http://www.mamicode.com/new Array();"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=http://www.mamicode.com/array();>
显示效果如下图:
四、前台传递一维数组和二维数组,后台返回二维数组(json格式)
Javascript代码:
$(function(){ var my_data=http://www.mamicode.com/new Array();"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=http://www.mamicode.com/array();>
显示效果如下图:
jquery下php与ajax的数据交换方式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。