Mam więc ten przycisk, który dodaje nowy wiersz do tabeli, jednak moim problemem jest to, że nie nasłuchuje on .new_participant_form
już zdarzenia kliknięcia po wykonaniu metody append.
Kliknij opcję Dodaj nowy wpis, a następnie kliknij nazwę formularza.
$('#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_form
elementu, który jest już w dokumencie. Aby działało to również w przypadku elementów, które dodasz później, możesz użyć delegowania zdarzeń, tak jak to pokazała dystrybroy, lub dołączyć procedurę obsługi do każdej kotwicy przed jej wstawieniem (ta pierwsza jest bardziej wydajna).