JQuery добавление элементов, включая прослушиватель удаления - PullRequest
2 голосов
/ 15 января 2012

Как лучше всего добавлять элементы, в т.ч.ссылку на удаление себя, на 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);
            });
        }
    }
}

Странный эффект: независимо от того, какую ссылку я нажимаю, всегда удаляется последний элемент.Почему это так и есть ли более элегантный способ сделать это?

С уважением, Эрик

Ответы [ 2 ]

1 голос
/ 15 января 2012

Вы можете заменить это на:

// 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();
});
0 голосов
/ 15 января 2012

Я бы переместил материал события из цикла:

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
});
...