--- title: 'Document: readystatechange 事件' slug: Web/API/Document/readystatechange_event tags: - Reference - XMLHttpRequest - interactive - 事件 translation_of: Web/API/Document/readystatechange_event original_slug: Web/Events/readystatechange事件 ---
当文档的 {{domxref("Document.readyState", "readyState")}} 属性发生改变时,会触发 readystatechange
事件。
是否冒泡 | 否 |
---|---|
是否可取消 | 否 |
接口 | {{domxref("Event")}} |
Event handler 属性 | onreadystatechange |
<div class="controls"> <button id="reload" type="button">Reload</button> </div> <div class="event-log"> <label>Event log:</label> <textarea readonly class="event-log-contents" rows="8" cols="30"></textarea> </div>
body { display: grid; grid-template-areas: "control log"; } .controls { grid-area: control; display: flex; align-items: center; justify-content: center; } .event-log { grid-area: log; } .event-log-contents { resize: none; } label, button { display: block; } #reload { height: 2rem; }
const log = document.querySelector('.event-log-contents'); const reload = document.querySelector('#reload'); reload.addEventListener('click', () => { log.textContent =''; window.setTimeout(() => { window.location.reload(true); }, 200); }); window.addEventListener('load', (event) => { log.textContent = log.textContent + 'load\n'; }); document.addEventListener('readystatechange', (event) => { log.textContent = log.textContent + `readystate: ${document.readyState}\n`; }); document.addEventListener('DOMContentLoaded', (event) => { log.textContent = log.textContent + `DOMContentLoaded\n`; });
{{ EmbedLiveSample('Live_example', '100%', '160px') }}
规范 | 状态 | 备注 |
---|---|---|
{{SpecName("HTML WHATWG", "indices.html#event-readystatechange", "readystatechange")}} | {{Spec2("HTML WHATWG")}} |
{{Compat("api.Document.readystatechange_event")}}
IE 浏览器是一直支持 readystatechange
事件的,可作为 DOMContentLoaded 事件的替代方法(参见Browser compatibility的注释 [2])。