Ajax
AJAX是异步的JavaScript和XML(Asynchronous JavaScript And XML)。简单点说,就是使用 XMLHttpRequest 对象与服务器通信。 它可以使用JSON,XML,HTML和text文本等格式发送和接收数据。AJAX最吸引人的就是它的“异步”特性,也就是说他可以在不重新刷新页面的情况下与服务器通信,交换数据,或更新页面。
创建一个简单的Ajax
创建 XMLHttpRequest 对象
1
2
3
4
5if (window.XMLHttpRequest) { // Mozilla, Safari, IE7+ ...
httpRequest = new XMLHttpRequest();
} else if (window.ActiveXObject) { // IE 6 and older
httpRequest = new ActiveXObject("Microsoft.XMLHTTP");
}绑定onreadystatechange 事件
1
2
3httpRequest.onreadystatechange = function(){
// Process the server response here.
};向服务器发送请求
1
2httpRequest.open('GET', 'http://www.example.org/some.file', true);
httpRequest.send();
完整的例子
1 | function ajax(url, cb) { |
httpRequest.readyState的值
- 0 (未初始化) or (请求还未初始化)
- 1 (正在加载) or (已建立服务器链接)
- 2 (加载成功) or (请求已接受)
- 3 (交互) or (正在处理请求)
- 4 (完成) or (请求已完成并且响应已准备好)
访问服务端返回的数据
- httpRequest.responseText
- 服务器以文本字符的形式返回
- httpRequest.responseXML
- 以 XMLDocument 对象方式返回,之后就可以使用JavaScript来处理
GET 注意事项
- 如果不设置响应头
Cache-Control: no-cache
浏览器将会把响应缓存下来而且再也不无法重新提交请求。你也可以添加一个总是不同的 GET 参数,比如时间戳或者随机数 (详情见 bypassing the cache)
POST 请求
POST请求则需要设置RequestHeader
告诉后台传递内容的编码方式以及在send方法里传入对应的值
1 | xhr.open("POST", url, true); |
Ajax与cookie
- ajax会自动带上同源的cookie,不会带上不同源的cookie
- 可以通过前端设置withCredentials为true, 后端设置Header的方式让ajax自动带上不同源的cookie,但是这个属性对同源请求没有任何影响。会被自动忽略。
1 | var xhr = new XMLHttpRequest(); |
什么是Ajax?
AJAX是异步的JavaScript和XML(Asynchronous JavaScript And XML)。
简单点说,就是使用 XMLHttpRequest
对象与服务器通信。 它可以使用JSON,XML,HTML和text文本等格式发送和接收数据。
AJAX最吸引人的就是它的“异步”特性,也就是说它可以在不重新刷新页面的情况下与服务器通信,交换数据,或更新页面。
你可以使用AJAX最主要的两个特性做下列事:
- 在不重新加载页面的情况下发送请求给服务器。
- 接受并使用从服务器发来的数据。
Step 1 – 怎样发送http请求
为了使用JavaScript向服务器发送一个http请求,你需要一个包含必要函数功能的对象实例。这就是为什么会有 XMLHttpRequest
的原因。
1 | // Old compatibility code, no longer needed. |
发送一个请求后,你会收到响应。在这一阶段,你要告诉XMLHttp请求对象是由哪一个JavaScript函数处理响应,在设置了对象的 onreadystatechange
属性后给他命名,当请求状态改变时调用函数。
1 | httpRequest.onreadystatechange = nameOfTheFunction; |
要注意的是,函数名后没有参数,因为你把一个引用赋值给了函数,而不是真正的调用了它。
如果不使用函数名的方式,你还可以用JavaScript的匿名函数响应处理的动作,就像下面这样:
1 | httpRequest.onreadystatechange = function(){ |
接下来,声明当你接到响应后要做什么,你要发送一个实际的请求,通过调用HTTP请求对象的 open()
和 send()
方法,像下面这样:
1 | httpRequest.open('GET', 'http://www.example.org/some.file', true); |
- 第三个参数是可选的,用于设置请求是否是异步的。如果设为
true
(默认值),即开启异步,JavaScript就不会在此语句阻塞,使得用户能在服务器还没有响应的情况下与页面进行交互。
send()
方法的参数可以是任何你想发送给服务器的内容,如果是 POST
请求的话。发送表单数据时应该用服务器可以解析的格式,像查询语句:
1 | "name=value&anothername="+encodeURIComponent(myVar)+"&so=on" |
如果你使用 POST 数据,那就需要设置请求的MIME类型。比如,在调用 send()
方法获取表单数据前要有下面这个:
1 | httpRequest.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); |
Step 2 – 处理服务器响应
首先,函数要检查请求的状态。如果状态的值是 XMLHttpRequest.DONE
(对应的值是4),意味着服务器响应收到了并且是没问题的,然后就可以继续执行。
1 | if (httpRequest.readyState === XMLHttpRequest.DONE) { |
全部readyState状态值:
- 0 (未初始化) or (请求还未初始化)
- 1 (正在加载) or (已建立服务器链接)
- 2 (加载成功) or (请求已接受)
- 3 (交互) or (正在处理请求)
- 4 (完成) or (请求已完成并且响应已准备好)
接下来,点击HTTP响应的 response code。 可能的响应码都已经列在 W3C这个列表里。
通过检查响应码 200 OK
判断AJAX有没有成功。
1 | if (httpRequest.status === 200) { |
在检查完请求状态和HTTP响应码后, 你就可以用服务器返回的数据做任何你想做的了。你有两个方法去访问这些数据:
httpRequest.responseText
– 服务器以文本字符的形式返回httpRequest.responseXML
– 以 XMLDocument 对象方式返回,之后就可以使用JavaScript来处理
注意上面这一步只在你发起异步请求时有效(即 open()
的第三个参数未特别指定或设为 true
)。
Step 3 – 一个简单的例子
这个JavaScript会请求一个HTML文档 test.html
,包含 “I’m a test” 内容。然后我们 alert()
响应的内容。注意这个例子我们只是用了JavaScript,没有用jQuery。而且,HTML,XML和PHP文件都要放在用一个目录下。
1 | <button id="ajaxButton" type="button">Make a request</button> |
在这个例子中:
- 用户点击 “Make a request” 按钮;
- 事件处理调用
makeRequest()
函数; - 请求已通过然后(
onreadystatechange
)传给alertContents()
执行。 alertContents()
检查返回的响应是否OK,然后alert()
test.html
文件内容。
在通信错误的事件中(例如服务器宕机),在访问响应状态 onreadystatechange 方法中会抛出一个例外。为了缓和这种情况,则可以使用 try...catch
把 if...then
语句包裹起来。
1 | function alertContents() { |
Step 4 – 处理 XML 响应
首先,我们创建一个稍后将要请求的有效的 XML 文档。文档(test.html
)包含以下内容:
1 |
|
在脚本里我们只需要把请求行改为:
1 | ... |
然后在 alertContents()
里,我们把 alert(httpRequest.responseText)
改为:
1 | var xmldoc = httpRequest.responseXML; |
Step 5 – 处理数据
首先要添加一个文本到 HTML 中以方便用户输入名字:
1 | <label>Your name: |
还要添加事件处理程序,从表单中获取用户数据连同服务器端的UTL一并发送给 makeRequest() 函数:
1 | document.getElementById("ajaxButton").onclick = function() { |
我们还要修改 makeRequest()
让它接受用户数据并将其发给服务器。把请求方法从 GET
改为 POST
,把数据作为参数让 httpRequest.send()
调用。
1 | function makeRequest(url, userName) { |
为了在 alertContents()
中使用这个数据,我们可不能只是alert responseText
,我们要解析它并 alert computedString
,我们想要的属性:
1 | function alertContents() { |
1 | // test.php |