JQuery 添加元素,包括删除侦听器

发布于 2024-12-27 06:07:55 字数 617 浏览 3 评论 0原文

添加元素(包括元素)的最佳方式是什么?一个删除自身的链接,到一个div? 这几乎有效:

function displayElements(objekt) {
    $('#container').empty();
    for(var key in objekt) {
        if(objekt.hasOwnProperty(key)) {
            $('#container').append('<div id="' + key + '">' + 
                key +
                '<a id="del' + key + '">delete'</a></div>');
            $('#del' + key).click(function() {
                delete objekt[key];
                displayElements(objekt);
            });
        }
    }
}

奇怪的效果是,无论我单击哪个删除链接,最后一个元素总是被删除。 为什么会这样?有没有更优雅的方法来实现这一点?

问候,埃里克

What is the best way to add elements, incl. a link to remove themselves, to a div?
This almost works:

function displayElements(objekt) {
    $('#container').empty();
    for(var key in objekt) {
        if(objekt.hasOwnProperty(key)) {
            $('#container').append('<div id="' + key + '">' + 
                key +
                '<a id="del' + key + '">delete'</a></div>');
            $('#del' + key).click(function() {
                delete objekt[key];
                displayElements(objekt);
            });
        }
    }
}

The strange effect is, that no matter which delete link I click, always the last element gets deleted.
Why is that and is there a more elegant way to accomplish this?

Regards, Eriq

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

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

发布评论

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

评论(2

完美的未来在梦里 2025-01-03 06:07:55

您可以将其替换为:

// build your markup
function displayElements(objekt) {
    var container = $('#container').empty();
    for (var key in objekt) {
        if (objekt.hasOwnProperty(key)) {
            container.append('<div id="' + key + '">' + key + '<a id="del' + key + '">delete< /a></div > ');
        }
    }
}


displayElements(objekt);

// bind to all anchors who's ids start with 'del'
$("#container").on("click", "a[id^='del']", function() {
    $(this).remove();
});

You can replace that with:

// build your markup
function displayElements(objekt) {
    var container = $('#container').empty();
    for (var key in objekt) {
        if (objekt.hasOwnProperty(key)) {
            container.append('<div id="' + key + '">' + key + '<a id="del' + key + '">delete< /a></div > ');
        }
    }
}


displayElements(objekt);

// bind to all anchors who's ids start with 'del'
$("#container").on("click", "a[id^='del']", function() {
    $(this).remove();
});
缱绻入梦 2025-01-03 06:07:55

我会将事件内容移出循环:

function displayElements(objekt) {
  $('#container').empty();

  for (var key in objekt) {
    if (objekt.hasOwnProperty(key)) {
      var $div = $('<div />');
      $div.prop('class', 'delete');
      $div.append($('<a />').attr('id', 'del' + key).text('delete'));
    }
  }
}

$('.delete').on('click', 'a[id^="del"]', function() {
  // Delete your stuff
});

I'd move the event stuff out of the loop:

function displayElements(objekt) {
  $('#container').empty();

  for (var key in objekt) {
    if (objekt.hasOwnProperty(key)) {
      var $div = $('<div />');
      $div.prop('class', 'delete');
      $div.append($('<a />').attr('id', 'del' + key).text('delete'));
    }
  }
}

$('.delete').on('click', 'a[id^="del"]', function() {
  // Delete your stuff
});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文