创建和触发事件
2019-01-19 13:58 更新
本文演示如何创建和分派DOM事件。此类事件通常称为合成事件,而不是浏览器本身触发的事件。
创建自定义事件
可以使用Event
构造函数创建事件,如下所示:
var event = new Event('build');
// Listen for the event.
elem.addEventListener('build', function (e) { /* ... */ }, false);
// Dispatch the event.
elem.dispatchEvent(event);
上面的代码示例使用EventTarget.dispatchEvent()方法。
大多数现代浏览器都支持此构造函数(Internet Explorer是例外)。有关更详细的方法(适用于Internet Explorer),请参阅下面的老式方法。
添加自定义数据 - CustomEvent()
要向事件对象添加更多数据,存在CustomEvent接口,detail属性可用于传递自定义数据。
例如,可以按如下方式创建事件:
var event = new CustomEvent('build', { detail: elem.dataset.time });
这将允许您访问事件侦听器中的其他数据:
function eventHandler(e) {
console.log('The time is: ' + e.detail);
}
老式方法
较旧的创建事件的方法使用受Java启发的API。以下是一个示例:
// Create the event.
var event = document.createEvent('Event');
// Define that the event name is 'build'.
event.initEvent('build', true, true);
// Listen for the event.
elem.addEventListener('build', function (e) {
// e.target matches elem
}, false);
// target can be any Element or other EventTarget.
elem.dispatchEvent(event);
事件冒泡
通常需要从子元素触发事件,并让祖先捕获它;可选地,使用数据:
<form>
<textarea></textarea>
</form>
const form = document.querySelector('form');
const textarea = document.querySelector('textarea');
// Create a new event, allow bubbling, and provide any data you want to pass to the "details" property
const eventAwesome = new CustomEvent('awesome', {
bubbles: true,
detail: { text: () => textarea.value }
});
// The form element listens for the custom "awesome" event and then consoles the output of the passed text() method
form.addEventListener('awesome', e => console.log(e.detail.text()));
// As the user types, the textarea inside the form dispatches/triggers the event to fire, and uses itself as the starting point
textarea.addEventListener('input', e => e.target.dispatchEvent(eventAwesome));
创建和动态调度的事件
元素可以侦听尚未创建的事件:
<form>
<textarea></textarea>
</form>
const form = document.querySelector('form');
const textarea = document.querySelector('textarea');
form.addEventListener('awesome', e => console.log(e.detail.text()));
textarea.addEventListener('input', function() {
// Create and dispatch/trigger an event on the fly
// Note: Optionally, we've also leveraged the "function expression" (instead of the "arrow function expression") so "this" will represent the element
this.dispatchEvent(new CustomEvent('awesome', { bubbles: true, detail: { text: () => textarea.value } }))
});
触发内置事件
此示例演示如何使用DOM方法模拟复选框上的单击(以编程方式生成单击事件)。
function simulateClick() {
var event = new MouseEvent('click', {
view: window,
bubbles: true,
cancelable: true
});
var cb = document.getElementById('checkbox');
var cancelled = !cb.dispatchEvent(event);
if (cancelled) {
// A handler called preventDefault.
alert("cancelled");
} else {
// None of the handlers called preventDefault.
alert("not cancelled");
}
}
以上内容是否对您有帮助:
更多建议: