Entonces, tengo este botón que agrega una nueva fila a la tabla, sin embargo, mi problema es que ya no escucha el .new_participant_formevento de clic después de que se haya realizado el método de adición.
Haga clic en Agregar nueva entrada y luego haga clic en el nombre del formulario.
$('#add_new_participant').click(function() {
var first_name = $('#f_name_participant').val();
var last_name = $('#l_name_participant').val();
var role = $('#new_participant_role option:selected').text();
var email = $('#email_participant').val();
$('#registered_participants').append('<tr><td><a href="#" class="new_participant_form">Participant Registration</a></td><td>'+first_name+ ' '+last_name+'</td><td>'+role+'</td><td>0% done</td></tr>');
});
$('.new_participant_form').click(function() {
var $td = $(this).closest('tr').children('td');
var part_name = $td.eq(1).text();
alert(part_name);
});
});
HTML
<table id="registered_participants" class="tablesorter">
<thead>
<tr>
<th>Form</th>
<th>Name</th>
<th>Role</th>
<th>Progress </th>
</tr>
</thead>
<tbody>
<tr>
<td><a href="#" class="new_participant_form">Participant Registration</a></td>
<td>Smith Johnson</td>
<td>Parent</td>
<td>60% done</td>
</tr>
</tbody>
</table>
<button id="add_new_participant"></span>Add New Entry</button>

new_participant_formelemento que ya está en el documento. Para que funcione para los elementos que también agregará más adelante, puede usar la delegación de eventos, como ha demostrado distrofia, o adjuntar el controlador a cada ancla antes de insertarla (la primera es más eficiente).Respuestas:
Usar en :
$('#registered_participants').on('click', '.new_participant_form', function() {Para que el clic se delegue a cualquier elemento que
#registered_participantstenga la clasenew_participant_form, incluso si se agrega después de vincular el controlador de eventos.fuente
$(document).on('click', '.new_participant_form', function() {});?#registered_participantspero para ser justos, esta desaceleración es tan pequeña que es irrelevante. En general, es mejor apuntar al elemento correcto porque es más limpio.El
.on()método se utiliza para delegar eventos a elementos, agregados dinámicamente o ya presentes en el DOM:// STATIC-PARENT on EVENT DYNAMIC-CHILD $('#registered_participants').on('click', '.new_participant_form', function() { var $td = $(this).closest('tr').find('td'); var part_name = $td.eq(1).text(); console.log( part_name ); }); $('#add_new_participant').click(function() { var first_name = $.trim( $('#f_name_participant').val() ); var last_name = $.trim( $('#l_name_participant').val() ); var role = $('#new_participant_role').val(); var email = $('#email_participant').val(); if(!first_name && !last_name) return; $('#registered_participants').append('<tr><td><a href="#" class="new_participant_form">Participant Registration</a></td><td>' + first_name + ' ' + last_name + '</td><td>' + role + '</td><td>0% done</td></tr>'); });<table id="registered_participants" class="tablesorter"> <thead> <tr> <th>Form</th> <th>Name</th> <th>Role</th> <th>Progress </th> </tr> </thead> <tbody> <tr> <td><a href="#" class="new_participant_form">Participant Registration</a></td> <td>Smith Johnson</td> <td>Parent</td> <td>60% done</td> </tr> </tbody> </table> <input type="text" id="f_name_participant" placeholder="Name"> <input type="text" id="l_name_participant" placeholder="Surname"> <select id="new_participant_role"> <option>Parent</option> <option>Child</option> </select> <button id="add_new_participant">Add New Entry</button> <script src="//ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>Leer más: http://api.jquery.com/on/
fuente
Este problema podría resolverse como se mencionó usando las
.onversiones de jQuery 1.7+.Desafortunadamente, esto no funcionó dentro de mi código (y tengo 1.11), así que usé:
$('body').delegate('.logout-link','click',function() {http://api.jquery.com/delegate/
// jQuery 1.4.3+ $( elements ).delegate( selector, events, data, handler ); // jQuery 1.7+ $( elements ).on( events, selector, data, handler );¡Este comentario podría ayudar a otros :)!
fuente
PRUEBA ESTO
A partir de la versión 1.7+ de jQuery, el método on () es el nuevo reemplazo de los métodos bind (), live () y delegate ().
ASÍ QUE AGREGUE ESTO,
$(document).on("click", "a.new_participant_form" , function() { console.log('clicked'); });O para más información CONSULTAR AQUÍ
fuente
** Problema resuelto **
// Se cambió al método delegate () para usar la delegación del cuerpo
$("body").delegate("#boundOnPageLoaded", "click", function(){ alert("Delegated Button Clicked") });fuente