分享人:王寒
目录
1.背景介绍
2.知识剖析
3.常见问题
4.解决方案
5.编码实战
6.扩展思考
7.参考文献
8.更多讨论
即异步的 JavaScript 和 XML,是一种用于创建快速动态网页的技术; 传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。 使用AJAX则不需要加载更新整个网页,实现部分内容更新;
具体来说,AJAX包括以下几个步骤。
xmlhttprequest对象的用法
xhr.open("get","ajax_info.txt",false);
xhr.send(null);
send方法接受一个数据,即要作为请求主体的数据。如果不需要请求主体发回数据,则传回null; 收到响应后数据会填入xhr对象的属性:
在收到响应后,第一步先确定status属性,用来确定是否返回成功(状态为200); responseText属性就准备就绪,此外,状态码304表示请求的资源没有被修改; 但一般为了确保接受到适当的响应还需要检测上面两种状态码;
function sendAjax() {
//构造表单数据
var formData = new FormData();
formData.append('username', 'johndoe');
formData.append('id', 123456);
//创建xhr对象
var xhr = new XMLHttpRequest();
//设置xhr请求的超时时间
xhr.timeout = 3000;
//设置响应返回的数据格式
xhr.responseType = "text";
//创建一个 post 请求,采用异步
xhr.open('POST', '/server', true);
//注册相关事件回调处理函数
xhr.onload = function(e) {
if(this.status == 200||this.status == 304){
alert(this.responseText);
}
};
xhr.ontimeout = function(e) { ... };
xhr.onerror = function(e) { ... };
xhr.upload.onprogress = function(e) { ... };
//发送数据
xhr.send(formData);
}
1、IE浏览器下面的缓存问题
2、跨域问题
3、Ajax乱码问题
4、使用post提交的时候需要设置content-type为"application/x-www-form-urlencoded"
5、Ajax对象属性的大小写问题
6、Ajax状态为0的问题
xhr.open("get","xxxx.aspx?_dc="+new Date().getTime(),true);
就是在请求的后面 加上时间戳或是随机数,让url变成唯一,或者是,改成post请求。
(get和post请求的区别可参见 浅谈HTTP中Get与Post的区别)
3. Ajax乱码问题
乱码问题虽然我们目前遇到的不多,但是也属于比较常见的一个问题了。出现的主要原因就是编码不一致导致的。
如果出现乱码问题了,首先检查一下meta声明的charset要和请求的页面返回的charset一致。response.charset="gb2312 or utf-8"
4. 使用post提交的时候需要进行的设置
content-Type: application/x-www-form-urlencoded;
//jQuery中,
content-Type: application/x-www-form-urlencoded;charset=utf-8;
//AngularJS中$http
content-Type: application/json; charset=utf-8;
//使用原生Ajax需要在open以后才能使用xhr.setRequestHeader()方法,否则出错
xhr.open("post","xxxx.aspx",true);
xhr.setRequestHeader("content-type","application/x-www-form-urlencoded")
//用原生写时必须在open()方法之后send()方法之前调用
5. Ajax对象属性的大小写问题
有些浏览器比如火狐,对大小写是敏感的,if (xhr.readystate==4)这种写法,
在IE下是成立的,但是在Firefox下就行不通了,因为IE不区分大小写,Firefox是区分大小的。标准写法为if (xhr.readyState==4),同理还有属性
responseText,responseXML。习惯采用驼峰形式的写法可以避免这个问题。
6. Ajax状态0的问题
有时候在测试Ajax代码的时候加了 xhr.status==200的判断后,一直不执行xhr.status==200的代码,
这个就需要注意了。xhr.status==200是要通过服务器确认后来返回的,在服务器页面没有发生错误或者转向时才返回200状态的,
此状态和你通过浏览器访问页面时服务器定义的状态一致。直接拖进浏览器浏览结果或者双击运行html页面的,未发生错误时,此时的xhr.status是0,不是200。
AJAX的优缺点
get与post
ajax的优点:
ajax的缺点:
GET - 从指定的资源请求数据。 POST - 向指定的资源提交要被处理的数据
GET 请求可被缓存 GET 请求保留在浏览器历史记录中 GET 请求可被收藏为书签 GET 请求不应在处理敏感数据时使用 GET 请求有长度限制 GET 请求只应当用于取回数据
POST 请求不会被缓存 POST 请求不会保留在浏览器历史记录中 POST 不能被收藏为书签 POST 请求对数据长度没有要求
参考一:《JavaScript高级编程设计》
AJAX适用场景有哪些?
Ajax适用场景
Ajax不适用场景
谢谢观看
分享人:王寒