CodexBloom - Programming Q&A Platform

jQuery .on() not triggering for dynamically added elements with specific class

👀 Views: 54 đŸ’Ŧ Answers: 1 📅 Created: 2025-07-27
jquery dynamic-content event-delegation JavaScript

I'm testing a new approach and I'm converting an old project and I've looked through the documentation and I'm still confused about I'm experiencing an scenario where I want to attach click event handlers to dynamically added elements that share a specific class. I am using jQuery version 3.6.0 and I have tried using `.on()` with event delegation, but it seems that the click handler is not being triggered as expected. Here's a snippet of my code: ```javascript $(document).ready(function() { // Initial click handler for items already in the DOM $('.dynamic-item').on('click', function() { alert('Item clicked!'); }); // Function to add new items dynamically function addItem() { var newItem = $('<div class="dynamic-item">New Item</div>'); $('#container').append(newItem); } // Simulate adding items every 2 seconds setInterval(addItem, 2000); }); ``` Despite this setup, when new items are added to the `#container`, the click event does not trigger on them. I also tried moving the event handler inside the `addItem` function, but the same scenario continues. The console doesn't show any errors, and the handlers work fine for the items that are present on page load. Is there something I'm missing with event delegation here? I expected the click handler to work for any element with the class `.dynamic-item` that is added after the initial page load. I recently upgraded to Javascript stable. Thanks, I really appreciate it! Could this be a known issue?