无法使用 jQuery 删除动态添加的内容

发布于 2024-12-25 09:29:52 字数 786 浏览 3 评论 0原文

我使用 jQuery 让用户动态添加和删除表单字段,但它无法正常工作。

删除第一个字段(在 HTML 标记中硬编码)时它工作得很好,但它不允许我删除任何动态添加的字段。

这是我的 jQuery 代码:

$("#addDog").click(function(event)
{
    event.preventDefault();

    var doglist = <?php echo "'" . $javadogs . "'"; ?>;
    var newdog = '<div><select name="resDog[]" class="select">' + doglist + '</select><input type="text" class="shortinput" name="resResult[]" size="20" value="" /><a href="#" class="deleteDog"><img src="/admin/images/delete.png" alt="Remove dog" /></a></div>';
    $(this).parent().before(newdog);
});

$(".deleteDog").click(function(event)
{
    event.preventDefault();
    $(this).parent().remove();
});

我尝试使用 jQuery 的 .on() 函数,但这也不起作用。

I'm using jQuery to let users dynamically add and remove form fields, but it's not working properly.

It works perfectly fine when removing the first field (which is hard-coded in the HTML mark-up), but it won't let me remove any of the fields that have been added dynamically.

Here's my jQuery code:

$("#addDog").click(function(event)
{
    event.preventDefault();

    var doglist = <?php echo "'" . $javadogs . "'"; ?>;
    var newdog = '<div><select name="resDog[]" class="select">' + doglist + '</select><input type="text" class="shortinput" name="resResult[]" size="20" value="" /><a href="#" class="deleteDog"><img src="/admin/images/delete.png" alt="Remove dog" /></a></div>';
    $(this).parent().before(newdog);
});

$(".deleteDog").click(function(event)
{
    event.preventDefault();
    $(this).parent().remove();
});

I tried using jQuery's .on() function, but that didn't work either.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

不可一世的女人 2025-01-01 09:29:52

以下是如何使用 on

$(document).on("click", ".deleteDog", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

理想情况下,所有这些 deleteDog 按钮都将放置在某种容器中。如果所有这些按钮都位于 id 为 foo 的 div 中,则可以更有效地设置事件,如下所示:

$("#foo").on("click", ".deleteDog", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

现在,不再检查文档中任何位置的每次单击,而只检查那些按钮冒泡到 #foo 的点击次数是。


我猜您最初尝试像这样使用 on

$(".deleteDog").on("click", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

这在功能上等同于:

$(".deleteDog").bind("click", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

像这样省略选择器参数会创建一个直接绑定事件 - 仅元素调用 on 时与 .deleteDog 选择器匹配的内容将被连接。

应用选择器(就像在我的原始代码中一样)使其成为委托事件,jQuery 将侦听所有点击,如果它们源自具有 deleteDog 类的元素,则函数将会触发。

Here's how you want to use on

$(document).on("click", ".deleteDog", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

Ideally all of these deleteDog buttons will be housed in some sort of container. If all of these buttons were to be in a div with an id of foo, you would more efficiently set up the events like this:

$("#foo").on("click", ".deleteDog", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

Now, instead of every click anywhere in the document being inspected, only those clicks that bubble up to #foo are.


I'm guessing you originally tried to use on like this:

$(".deleteDog").on("click", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

This is functionally identical to saying:

$(".deleteDog").bind("click", function(e) {
    e.preventDefault();
    $(this).parent().remove();
});

Omitting the selector parameter like this creates a directly-bound event—only the elements that match the .deleteDog selector at the time on is called will be wired.

Applying a selector—like in my original code—makes it a delegated event—jQuery will listen for all clicks, and if they originate from an element with the class deleteDog, the function will fire.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文