CodexBloom - Programming Q&A Platform

jQuery .on() not binding events to dynamically created input fields after form submission

πŸ‘€ Views: 92 πŸ’¬ Answers: 1 πŸ“… Created: 2025-06-24
jquery events dynamic-elements JavaScript

I'm stuck on something that should probably be simple. I'm working with an scenario where I'm trying to bind the `change` event to dynamically created input fields after a form submission using jQuery. Initially, I create a form with a few input fields and bind the event correctly, but when I submit the form, I replace the input fields with new ones based on user input. The new fields do not trigger the `change` event as expected. Here's the code that I'm using: ```javascript $(document).ready(function() { $('#myForm').on('change', 'input', function() { console.log('Input changed: ' + $(this).val()); }); $('#submitButton').on('click', function(e) { e.preventDefault(); // Simulate input replacement after form submission $('#myForm').html('<input type="text" name="newInput" />'); }); }); ``` The event handler for the `change` event is working for the initial input fields, but after the form is submitted and the input is replaced, any changes to the new input field do not trigger the console log. I've tried using `.on()` with event delegation, but it doesn’t seem to work with the new inputs. I also confirmed that the new input fields are being added to the DOM as expected. I've gone through the jQuery documentation and examples but couldn't find a solution. Is there something I'm missing in the event delegation, or do I need to approach this differently? Any insights would be greatly appreciated!