世界上有些事就是为了让你干了以后后悔而设,所以你不管干了什么事,都不要后悔。

《AJAX高级程序设计》读书笔记(五)

AJAX通信控制模式

提交节流

我怎么感觉AJAX是节不了流的啊,如果能带来完美的用户体验,反倒还增流了。

比如这个用户注册,我总得考虑浏览器是否支持AJAX,所以设定了一个isFormValid()用来检查是否所有表单数据通过AJAX检查,这个参数看来也得传到后台去。因为倘若不支持ajax,提交给后台,照常检查页面,倘若支持ajax,则那个参数用来跳过后台检查数据这段代码。

这有点增流啊。

取事件对象,怎么都喜欢传个event参数或者用window.event,这多麻烦,我则喜欢用this。

javascript是基于对象的,无论事件或方法,它都源自this-对象。

register.php
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
2  <HTML>
3 <HEAD>
4 <TITLE>提交顾客表单</TITLE>
5 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
6 </HEAD>
7 <script type="text/javascript">
8
9 function createXHR(){
10 if(typeof XMLHttpRequest != "undefined"){
11 return new XMLHttpRequest();
12 }else if(window.ActiveXObject){
13 var aVersions = ["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0"];
14 for(var i = 0;i <aVersions.length; i++){
15 return new ActiveXObject(aVersions[i]);
16 }
17 }
18 }
19
20 function requestToServer(domId){
21 var loadingO = this;
22 var queryString = encodeURI(this.name+"="+this.value);
23 var XHR = null;
24 XHR = createXHR();
25 XHR.open('post',"check.php",true);
26 XHR.onreadystatechange = function(){
27 if(XHR.readyState == 4){
28 if(XHR.status == 200){
29 var returnText = XHR.responseText.split('||');
30 var statuNode = document.createElement('span');
31 statuNode.innerHTML = returnText[0];
32 if(returnText[1] == "yes"){
33 loadingO.valid = 'true';
34 }else{
35 loadingO.valid = 'false';
36 }
37 //alert(this.name);
38 loadingO.parentNode.appendChild(statuNode);
39 }
40 }
41 };
42 XHR.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
43 XHR.send(queryString);
44 }
45
46 function isFormValid(){
47 var infoForm = document.forms[0];
48 for(var i = 0; i<infoForm.elements.length; i++){
49
50 if(infoForm.elements[i].valid == 'false'){
51 alert(i);
52 return false;
53 }
54 }
55 return true;
56 }
57
58 window.onload = function(){
59 var myname = document.getElementById("myname");
60 myname.valid = 'false';
61 myname.onchange = requestToServer;
62
63 var myaddress = document.getElementById("myaddress");
64 myaddress.valid = 'false';
65 myaddress.onchange = requestToServer;
66
67 document.getElementById('but').onclick = function(){
68 if(isFormValid()){alert(111);}else{alert(222);}
69 };
70 };
71 </script>
72 <BODY>
73 <form action="check.php" method="post">
74 <p>顾客名:<input type="text" name="myname" id="myname" /></p>
75 <p>地址:<input type="text" name="myaddress" id="myaddress" /></p>
76 <p><input type="submit" value="提交" /><input type="button" id="but" value="测试" /></p>
77 </form>
78 </BODY>
79 </HTML>

 

check.php
1 <?php
2 $name = array('name1','name2','name3');
3 $address = array('address1','address2','address3');
4 if(isset($_POST['myname'])){
5 $myname = $_POST['myname'];
6 if(in_array($myname,$name)){
7 echo '用户名合法||yes';
8 }else{
9 echo '用户名不合法||no';
10 }
11 }elseif(isset($_POST['myaddress'])){
12 $myaddress = $_POST['myaddress'];
13 if(in_array($myaddress,$address)){
14 echo '地址合法||yes';
15 }else{
16 echo '地址不合法||no';
17 }
18 }else{
19 echo "ccccccccccc";
20 }
21 ?>

在网上查了下AJAX的GET和POST的注意点:

GET访问浏览器认为是等幂的
就是一个相同的URL,只有一个结果相同是指整个URL字符串完全匹配。
所以第二次访问的时候,如果URL字符串没变化,浏览器是直接拿出了第一次访问的结果。
POST则认为是一个变动性访问,浏览器认为POST的提交必定是有改变的。
防止GET的等幂访问,就在URL后面加上?+new Date(),总之就是使每次访问的URL字符串不一样的。
设计WEB页面的时候 也应该遵守这个原则
Get方式:   用get方式可传送简单数据,但大小一般限制在1KB下,数据追加到url中发送(http的header传送),也就是说,浏览器将各个表单字段元素及其数据按照URL参数的格式附加在请求行中的资源路径后面。另外最重要的一点是,它会被客户端的浏览器缓存起来,那么,别人就可以从浏览器的历史记录中,读取到此客户的数据,比如帐号和密码等。因此,在某些情况下,get方法会带来严重的安全性问题。
Post方式:
当使用POST方式时,浏览器把各表单字段元素及其数据作为HTTP消息的实体内容发送给Web服务器,而不是作为URL地址的参数进行传递,使用POST方式传递的数据量要比使用GET方式传送的数据量大的多。
总之,GET方式传送数据量小,处理效率高,安全性低,会被缓存,而POST反之。
使用get方式需要注意:
1 对于get请求(或凡涉及到url传递参数的),被传递的参数都要先经encodeURIComponent方法处理.例:var url = "update.php?username=" +encodeURIComponent(username) + "&content=" +encodeURIComponent(content)+"&id=1" ;
使用Post方式需注意:
1.设置header的Context-Type为application/x-www-form-urlencode确保服务器知道实体中有参数变量.通常使用XmlHttpRequest对象的SetRequestHeader("Context-Type","application/x-www-form-urlencoded;")。例:xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
2.参数是名/值一一对应的键值对,每对值用&号隔开.如 var name=abc&sex=man&age=18,注意var name=update.php?
abc&sex=man&age=18以及var name=?abc&sex=man&age=18的写法都是错误的;
3.参数在Send(参数)方法中发送,例: xmlHttp.send(name); 如果是get方式,直接 xmlHttp.send(null);
AJAX产生乱码的原因:
1、xtmlhttp 返回的数据默认的字符编码是utf-8,如果客户端页面是gb2312或者其它编码数据就会产生乱码
2、post方法提交数据默认的字符编码是utf-8,如果服务器端是gb2312或其他编码数据就会产生乱码
解决办法有:
1、若客户端是gb2312编码,则在服务器指定输出流编码
2、服务器端和客户端都使用utf-8编码
gb2312:header('Content-Type:text/html;charset=GB2312');
utf8:header('Content-Type:text/html;charset=utf-8');

posted on 2010-05-26 21:11  kingQueenyun  阅读(211)  评论(0编辑  收藏  举报

导航