Jquery下Ajax与PHP数据交换
2015-10-12 16:50
573 查看
一、前台传递字符串变量,后台返回字符串变量(非json格式) Javascript代码: 这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对...
一、前台传递字符串变量,后台返回字符串变量(非json格式)Javascript代码:这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对汉字字符串进行了编码,并且对返回 的字符串使用unescape()函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决 汉字乱码问题的方式如下: PHP:header('Content-Type:text/html;charset=GB2312'); $(function(){ var my_data="前台变量"; my_data=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=$_POST['trans_data']; echo $backValue."+后台返回"; ?> 显示效果如下图所示: 二、前台传递多个一维数组,后台返回字符串变量(非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=gb2312');//使用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); ?> 显示效果如下图: |
相关文章推荐
- jquery filter() find()
- jQuery
- JQuery中$.ajax()方法参数详解
- 真正的LazyLoad按需加载
- jQuery $(document).ready()和JavaScript onload事件详解区别
- jquery validate 修改错误信息的显示位置
- 如何利用jQuery post传递含特殊字符的数据
- JS/jQuery常用代码片段
- 判断浏览器的代码的原生js和jquery
- jQuery(一)sibling方法
- jQuery(二)DOM加载完成后要执行的函数
- jQuery(三)4.从DOM中删除所有匹配的元素
- jquery easyui 设置默认页码
- jQuery .Ajax Error Handling Function
- 省市联动——季度-月份下拉列表框——jQuery版
- 省市联动——季度-月份下拉列表框——省市联动类库版
- jQuery ajax - serialize() 方法
- jQuery select 选中问题
- jQuery源码分析之wrap,wrapInner,wrapAll,unwrap方法
- JQuery Mobile学习笔记