是否有任何方法将数据附加到jQuery事件对象,因为它在DOM上传播?
为了澄清,如果你有三个嵌套的div,每个div都有一个click事件监听器,那么点击最里面的div会导致从最里面到最外面调用所有三个处理程序(事件传播101)。我想要做的是在每个处理程序中向事件对象添加一些数据,这些数据库可供下一层访问。
我该怎么做?
答案 0 :(得分:40)
jQuery传递的事件对象是本机事件对象的包装器。冒泡发生在javascript /浏览器级别,因此本机事件对象似乎在所有事件处理程序之间共享。
$('div').click(function(e) {
e.originalEvent.attribute = (e.originalEvent.attribute || "") +
" " + $(this).prop("className");
alert(e.originalEvent.attribute);
});
在Chrome,Firefox,Safari,IE9和IE10中测试过。如果您在其他浏览器中测试,请使用结果进行评论。
答案 1 :(得分:4)
虽然您无法直接将数据附加到活动中,但您仍然可以通过jQuery targetElement
将数据附加到data()
:
$('div').click(function(e) {
var info = $(e.target).data('info') || '';
$(e.target).data('info', info + ' ' + $(this).attr('class'));
});
答案 2 :(得分:1)
也许我已经误解了这个问题,但是我遇到了这个StackOverflow页面,同时也在寻找一种方法来做同样的事情。
我发现你可以在每个处理程序的末尾返回你想要传递的值/值,然后使用event.result
属性在后续处理程序中访问它们吗?