
AJAX即“Asynchronous Javascript And XML
”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。
AJAX = 异步 JavaScript和XML(标准通用标记语言的子集)。
AJAX 是一种用于创建快速动态网页的技术。
通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个网页页面。
•"xml": 返回 XML
文档,可用 jQuery
处理。
•"html": 返回纯文本 HTML 信息;包含的 script 标签会在插入 dom 时执行。
•"script": 返回纯文本 JavaScript
代码。不会自动缓存结果。除非设置了 "cache" 参数。注意:在远程请求时(不在同一个域下),所有 POST 请求都将转为 GET 请求。(因为将使用 DOM 的 script标签来加载)
•"json": 返回 JSON 数据 。
•"jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery
将自动替换 ? 为正确的函数名,以执行回调函数。
•"text": 返回纯文本字符串
一、前台传递字符串变量,后台返回字符串变量(非json格式)
这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript
函数escape()
对汉字字符串进行了编码,并且对返回的字符串使用unescape()
函数进行解码,使得汉字得以正常显示。当然了,后台PHP代码也添加了头文件,以保证汉字字符串不会出现乱码。各种后台代码解决
汉字乱码问题的方式如下:
1 | PHP:header( 'Content-Type:text/html;charset=GB2312' ); |
Javascript
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | $( 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
代码:
1 2 3 | header( 'Content-Type:text/html; charset=gb2312' ); //使用gb2312编码,使中文不会变成乱码 $backValue = $_POST [ 'trans_data' ]; echo $backValue . "+后台返回" ; |
二、前台传递多个一维数组,后台返回字符串变量(非json格式)
在非json格式下,后台只能返回字符串,如果想后台返回数组,可以采用json格式,在本文的后面会详细介绍。Javascript
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | $( 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
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | //读取第一个数组 $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
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | $( 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成功 } alert(back); } }); }); |
PHP
代码:
1 2 3 4 5 | 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
代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | $( 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成功 } alert(back); } }); }); |
PHP
代码:
1 2 3 4 5 6 | 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 ); |