Я пытаюсь использовать .on()
, чтобы добавить текстовое поле при щелчке динамически созданной кнопки. Однако по какой-то причине я не могу заставить ее работать. Кто-нибудь видит, что случилось? Спасибо за любую помощь и извините, если это что-то очевидное (я боюсь, что это может быть, но я просто не вижу этого).Проблемы с JQuery .on()
$('#the-basics input.typeahead').keyup(function() {
var prs = $(this).val().split(' ');
if (!$("#the-basics span.newEntityButtons").length) {
var $newEntity = $('<span class="newEntityButtons">' + '</span>');
$newEntity.appendTo($("#the-basics"));
var $newPerson = $('<input type="button" value="New Person" id="addpersonbutton" class="newHolder newPerson" />');
$newPerson.appendTo($("span.newEntityButtons"));
}
});
$('div#example').on('click', '#addpersonbutton', function() {
var epo = new Date().getTime();
var theelement = '<span class="nested-fields person">' +
'<input id="stockholder_people_attributes_' + epo + '_fname" name="stockholder[people_attributes][' + epo + '][fname]" value="' + prs[0] + '">' +
'<a class="glyphicon glyphicon-trash remove_fields existing" href="#"></a>' +
'</span>';
$('div.new_person.new_fields').prepend(theelement);
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="example">
<div id="the-basics">
<input class="typeahead">
</div>
<div class="new_person new_fields">
</div>
</div>
удалить хэш из идентификатора 'ид = "addpersonbutton"' вместо 'ид = "# addpersonbutton"' – jcubic
согласен с @jcubic, также убедитесь, этот идентификатор не должен быть одинаковым для нескольких элементов. Это нарушит ваш код jquery для обработки событий с помощью ids. 'id =" # addpersonbutton "изменить эту строку так, чтобы идентификатор был уникальным все время. –
@jcubic хороший улов; к сожалению, есть что-то еще неправильное: -P – neanderslob