HTMLElement:error 事件
当资源未能加载或无法使用时,会在元素上触发 error 事件。例如,如果脚本出现执行错误,或者找不到图像或图像无效。
此事件不可取消,也不会冒泡。
语法
在诸如 addEventListener() 之类的方法中使用事件名称,或设置事件处理程序属性。
js
addEventListener("error", (event) => { })
onerror = (event) => { }
事件类型
如果事件是由用户界面元素生成的,则事件对象是 UIEvent 实例;否则,则是 Event 实例。
示例
实时示例
HTML
html
<div class="controls">
<button id="img-error" type="button">Generate image error</button>
<img class="bad-img" />
</div>
<div class="event-log">
<label for="eventLog">Event log:</label>
<textarea
readonly
class="event-log-contents"
rows="8"
cols="30"
id="eventLog"></textarea>
</div>
JavaScript
js
const log = document.querySelector(".event-log-contents");
const badImg = document.querySelector(".bad-img");
badImg.addEventListener("error", (event) => {
log.textContent += `${event.type}: Loading image\n`;
console.log(event);
});
const imgError = document.querySelector("#img-error");
imgError.addEventListener("click", () => {
badImg.setAttribute("src", "i-dont-exist");
});
结果
规范
| 规范 |
|---|
| UI 事件 # event-type-error |
| HTML # 事件-错误 |
浏览器兼容性
加载中…