Monday, May 20, 2024
 Popular · Latest · Hot · Upcoming
96
rated 0 times [  97] [ 1]  / answers: 1 / hits: 18622  / 8 Years ago, tue, november 15, 2016, 12:00:00

In jQuery there is .on() which can be used as:



$(document).on('click', '.foo', function() { /* ... */ });


This listens for click events on all DOM elements with the class .foo.
However, this also listens for any eventual elements added to the DOM later, so it is not equal to:



var elements = document.getElementsByClassName('foo');
for (var element in elements) {
element.addEventListener('click', function() { /* ... */ });
}


How do I do this in plain JavaScript? Am I supposed to use a MutationObserver? If so, then how? If not, then what?


More From » jquery

 Answers
22

That called event delegation, in the pure javascript you could attach the click event to the parent element then on click check if the clicked element match the target you want to click and perform the action you want ,like the example below :



document.getElementById(parent-item).addEventListener(click, function(e) {
// e.target is the clicked element!
// If it was an item with class 'foo'
if(e.target && e.target.className == foo) {
console.log(foo +e.target.innerText+ was clicked!);
}
});


Hope this helps.





document.getElementById(parent-item).innerHTML += <li class='foo'>Item 3</li>;

document.getElementById(parent-item).addEventListener(click, function(e) {
if(e.target && e.target.className == foo) {
console.log(foo +e.target.innerText+ was clicked!);
}
});

<ul id=parent-item>
<li class='foo'>Item 1</li>
<li class='foo'>Item 2</li>
</ul>




[#60057] Saturday, November 12, 2016, 8 Years  [reply] [flag answer]
Only authorized users can answer the question. Please sign in first, or register a free account.
josuea

Total Points: 609
Total Questions: 121
Total Answers: 104

Location: South Georgia
Member since Fri, Nov 13, 2020
4 Years ago
josuea questions
;