0

我看过关于这个主题的其他帖子,但他们总是在重绘时改变元素。我有一个项目列表,我想单击一个并通过 ajax 将其删除,然后重新绘制相同的列表并使其可单击。重绘后的点击不起作用。下面的代码重绘列表一次。然后“listto”项目不再可点击。我认为“开”应该处理这个问题。我怎样才能使这项工作?

$('.listto').on('click',function() {
    var tmp = $(this).attr('id').substr(1).split("|");
    $.ajax({url: '/contact/removefromlist/'+tmp[0]+'/'+tmp[1],
        success: function(data) {
            redrawtolist(data,tmp[1])
        }
    });
});

function redrawtolist(data,item) {
    var dat = JSON.parse(data);
    var str = "";
    $.each(dat, function(index, rel) {
        str += '<div id="t'+index+'|'+item+'" class="listto">'+rel+'</div>';
    });
    $('#tolist').html(str);
}
4

3 回答 3

2

当您替换元素时,处理程序就消失了。您可以使用事件委托来解决此问题:

$('#tolist').on('click', '.listto', function() {

现在只要#tolist不被替换,处理程序就不会被替换.listto元素移除。

on您可以在文档中阅读有关事件委托的更多信息。

于 2013-07-31T17:29:13.687 回答
2

将您的处理程序更改为:

$('#tolist').on('click', '.listto', function(){})

使用事件委托是将事件绑定到动态添加的元素的好方法。

您在此页面上有大量有关直接绑定和委托绑定的信息:http: //api.jquery.com/on/

于 2013-07-31T17:29:46.420 回答
1

您的问题是您将事件附加到尚未准备好接收该事件的元素。您应该将事件附加到父元素,然后您可以过滤.listto. 这样,添加可点击元素时并不重要,它会起作用。这称为事件委托。您将处理事件的任务委托给另一个元素。

HTML:

<body>
    <button>Click here to add book.</button>
</body>

还有你的 JS:

$(document).on("click", ".listto", function() {
    alert('it works!');
});

此外,在执行此操作时,不要将其附加到树上太高的父级。您想将其附加到最近的可能父元素。我们不需要在类似的东西上设置点击事件,document因为最好具体说明哪些元素将获得此事件。将其附加到document将意味着任何具有 类的元素.listto都可以点击并响应相同的代码。如果您想在不同的按钮中具有不同的功能,则不能,因为它们都响应附加到document.

$('#tolist').on("click", ".listto", function() { //This would be best, but will only work if #tolist is not dynamic
    alert('it works!');
});
于 2013-07-31T17:29:44.037 回答