在传播期间修改事件数据

时间:2011-08-19 06:49:05

标签: javascript jquery events

是否有任何方法将数据附加到jQuery事件对象,因为它在DOM上传播?

为了澄清,如果你有三个嵌套的div,每个div都有一个click事件监听器,那么点击最里面的div会导致从最里面到最外面调用所有三个处理程序(事件传播101)。我想要做的是在每个处理程序中向事件对象添加一些数据,这些数据库可供下一层访问。

我该怎么做?

3 个答案:

答案 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中测试过。如果您在其他浏览器中测试,请使用结果进行评论。

这是小提琴:http://jsfiddle.net/5AQqD/

答案 1 :(得分:4)

虽然您无法直接将数据附加到活动中,但您仍然可以通过jQuery targetElement将数据附加到data()

$('div').click(function(e) {
    var info = $(e.target).data('info') || '';
    $(e.target).data('info', info + ' ' + $(this).attr('class'));
});

这是小提琴:http://jsfiddle.net/eKVmU/

答案 2 :(得分:1)

也许我已经误解了这个问题,但是我遇到了这个StackOverflow页面,同时也在寻找一种方法来做同样的事情。

我发现你可以在每个处理程序的末尾返回你想要传递的值/值,然后使用event.result属性在后续处理程序中访问它们吗?

http://api.jquery.com/event.result/

的简单演示