我正在使用包含删除按钮的JQuery创建新的输入字段。删除按钮适用于原始元素,但不适用于使用JQuery创建的那些。
添加两个新电子邮件字段后的文档
<fieldset>
<legend>Send Email</legend>
<label>Emails(s) to send notice to.</label>
<p>
<input type="email" name="emails[]" style="cursor: auto; background-image: url(); background-attachment: scroll; background-position: 100% 50%; background-repeat: no-repeat;"><span class="btn_orange"><a href="#" class="remove_field">x</a></span>
</p>
<p><input type="email" name="emails[]"><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p><p><input type="email" name="emails[]"><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p><p>
<span class="btn_orange"><a class="add_email_button" href="#">Add Another Email</a></span>
</p>
<p>
<span class="btn_orange"><a class="ui-button">Send Email</a></span>
</p>
</fieldset>
脚本
<script type="text/javascript">
$(document).ready(
function () {
$("#importbutton").click(function () {
$("#ProgressBarImg").show();
$.get('@Url.Action("Import", "Import")', {},
function (data) {
$('body').html(data);
$('#ProgressBarImg').hide();
});
$("#importbutton").removeAttr("href");
}
);
var dialog = $("#emailSection").dialog({
autoOpen: false,
height: 400,
width: 475,
modal: true
});
$('#emailButton').click(function () {
$(dialog).dialog("open");
$('#emailButton').removeAttr('href');
});
$('.add_email_button').closest('p').click(function () {
var html = '<p><input type="email" name="emails[]" /><span class="btn_orange"><a href="#" class="remove_field">x</a></span></p>';
$(html).insertBefore($(this));
});
$('a.remove_field').closest('p').click(function () {
$(this).remove();
});
}
);
</script>
答案 0 :(得分:1)
您最初在页面上的元素上设置事件。添加新元素后,新元素没有处理程序,您可以添加它们,但这是最好的方式。
使用事件委派:http://jsfiddle.net/mendesjuan/4my1dhw1/
$(document).on('click', 'a.remove_field', function () {
$(this).closest('p').remove();
});
这意味着您正在聆听整个文档的点击次数,但只会过滤您感兴趣的内容。
第二个好处是你不需要为每个元素单独的处理程序,节省你的记忆
我发布的代码与您的代码有所不同,因为它要求您点击x
。当您点击<p>
中的任意位置时,您的代码将被删除。我改变它的原因是因为没有CSS选择器模仿closest('p')
所做的事情,那就是CSS选择器不会上升到树上。但是,我所拥有的内容似乎更有意义,而您可能只是using closest('p')
因为您想要删除整个<p>
,但您可以从处理程序内部执行此操作。
答案 1 :(得分:0)
对于在页面加载后添加的元素,您应该使用:
$('body').on('click', '.classSelector', function(e) {
});