使用本机javascript传递事件侦听器参数
Passing event listener parameters with native javascript?
我已经实现了三个类似jQuery的函数来控制我的自定义事件(我不能在我的项目中使用jQuery:-((:
var Events = {
on: function(evt, fn) {
document.addEventListener(evt, fn);
},
off: function() {
document.removeEventListener(evt, fn);
},
trigger: function(evt, params) {
var event; // The custom event that will be created
if (document.createEvent) {
event = document.createEvent("HTMLEvents");
event.eventName = evt;
event.initEvent(evt, true, true);
event.data = params;
window.dispatchEvent(event);
} else {
event = document.createEventObject();
event.eventName = evt;
event.eventType = evt;
event.data = params;
window.fireEvent("on" + event.eventType, event);
}
}
}
当我使用观察器实现时,我有:
Events.on('custom', function(e) {
console.log(e.data); // output [5,10,15]
});
Events.trigger('custom', [5, 10, 15]);
但我需要修改我的触发器函数,以便在事件对象之后用额外的参数调用监听器。类似于带有extraParameters属性的jquery.trigger((函数。例如:
Events.on('custom', function(e, a, b, c) {
console.log(a, b, c); //output [5,10,15]
});
Events.trigger('custom', [5,10,15]);
var event = new CustomEvent('build', { 'detail': 'test' });
// Listen for the event.
document.addEventListener('build', function (events) {
console.log(events.detail)
}, false);
// Dispatch the event.
document.dispatchEvent(event);
通过这种方式,您可以将数据传递给自定义创建的事件
参考
编辑:
if (window.CustomEvent) {
var event = new CustomEvent('my-event', {detail: {some: 'data'}});
} else {
var event = document.createEvent('CustomEvent');
event.initCustomEvent('my-event', true, true, {some: 'data'});
}
这是jquery等价于触发
相关文章:
- 如何在for循环中添加事件侦听器
- 未命中服务器发送的事件侦听器
- 如何覆盖原型中的事件侦听器
- 无法将事件侦听器附加到画布
- 如何在d3.js中自定义事件侦听器
- 在es6中,将带有回调的事件侦听器设置为可迭代的
- 事件侦听器未在chrome扩展中的options.js中启动
- IE8更改文本区域上的事件侦听器不工作
- 将事件侦听器添加到文档,而不是签入元素存在,然后添加事件侦听器
- javascript删除事件侦听器
- 我应该/如何清除mousemove JQuery事件侦听器
- 在JQuery中使用谷歌地图Api事件/侦听器
- 如何使用我的Jquery代码创建委托事件侦听器
- 'mousemove'画布中的事件侦听器-指针仅在最后一个矩形中更改
- 为什么此事件侦听器不工作
- 是否可以在数字输入框中的小按钮中添加事件侦听器
- 在Google Chrome扩展中添加事件侦听器
- SVG元素在转换后会丢失事件侦听器
- jQuery事件侦听器多次启动
- 如何在不删除类似侦听器的情况下从父对象中删除jQuery事件侦听器