Prototype equivalent for jQuery live function

2019-01-07 09:33发布

I need to bind event listener to all dynamicaly created elements by given css selector.

In jQuery, that would be

$(".foo").live("click", function(e) {
   // bar
});

Is there any equivalent in Prototype for this?

2条回答
Melony?
2楼-- · 2019-01-07 10:19

The correct answer to the question is here: http://gurde.com/2011/08/jquery-live-in-prototype/

The equivalent of the jQuery .live() in Prototype is the Event.on() method:

var handler = document.on(
    'click',
    'div[id^="post-"] .attached-post-thumbnail',
    function(event, element) {
        console.log(this);
        console.log(element);
    }.bind(this)
);

handler.stop();
handler.start();

Within the callback, the this keyword will always refer to the original element (in this case document).

查看更多
相关推荐>>
3楼-- · 2019-01-07 10:27

This is usually done with Event#findElement:

document.observe('click', function(e, el) {
  if (el = e.findElement('.foo')) {
    // there's your `el`
    // might want to stop event at this point - e.stop()
  }
});
查看更多
登录 后发表回答