XMLHttpRequest.readyState - Web API 接口参考 编辑
XMLHttpRequest.readyState 属性返回一个 XMLHttpRequest 代理当前所处的状态。一个 XHR 代理总是处于下列状态中的一个:
值 | 状态 | 描述 |
0 | UNSENT | 代理被创建,但尚未调用 open() 方法。 |
1 | OPENED | open() 方法已经被调用。 |
2 | HEADERS_RECEIVED | send() 方法已经被调用,并且头部和状态已经可获得。 |
3 | LOADING | 下载中; responseText 属性已经包含部分数据。 |
4 | DONE | 下载操作已完成。 |
- UNSENT
- XMLHttpRequest 代理已被创建, 但尚未调用 open() 方法。
- OPENED
- open() 方法已经被触发。在这个状态中,可以通过 setRequestHeader() 方法来设置请求的头部, 可以调用 send() 方法来发起请求。
- HEADERS_RECEIVED
- send() 方法已经被调用,响应头也已经被接收。
- LOADING
- 响应体部分正在被接收。如果
responseType
属性是“text”或空字符串,responseText
将会在载入的过程中拥有部分响应数据。 - DONE
- 请求操作已经完成。这意味着数据传输已经彻底完成或失败。
在IE中,状态有着不同的名称,并不是 UNSENT
,OPENED
, HEADERS_RECEIVED
, LOADING
和 DONE, 而是 READYSTATE_UNINITIALIZED
(0),READYSTATE_LOADING
(1) , READYSTATE_LOADED
(2) , READYSTATE_INTERACTIVE
(3) 和 READYSTATE_COMPLETE
(4) 。
示例
var xhr = new XMLHttpRequest();
console.log('UNSENT', xhr.readyState); // readyState 为 0
xhr.open('GET', '/api', true);
console.log('OPENED', xhr.readyState); // readyState 为 1
xhr.onprogress = function () {
console.log('LOADING', xhr.readyState); // readyState 为 3
};
xhr.onload = function () {
console.log('DONE', xhr.readyState); // readyState 为 4
};
xhr.send(null);
规范
规范 | 状态 | 注释 |
---|---|---|
XMLHttpRequest | Living Standard | WHATWG living standard |
浏览器兼容性
BCD tables only load in the browser
The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论