0

我正在构建一个简单的项目,例如 Twitter,但非常简单:) 用户主页(时间轴)上有很多推文。所以每条推文都有收藏按钮。当用户点击收藏按钮时,它会向服务器发送 AJAX 请求以存储收藏的推文。所以最喜欢的按钮是这样的:

<a href="#" id="1"><i class="icon-star-empty"></i></a>
<a href="#" id="2"><i class="icon-star"></i></a>
<a href="#" id="3"><i class="icon-star-empty"></i></a>
...
...

我使用以下 JavaScript 发送 AJAX 请求:

$("i").on("click", function() {

    if ( $(this).hasClass("icon-star-empty") ){
        ajaxURL = "/setFavorite"
    } else{
        ajaxURL = "/removeFavorite"
    }

    var linkID = $(this).parent().prop("id");
    var obj    = $(this);

    $.ajax({
        url: ajaxURL,
        type: "POST",
        data: {quoteID : linkID},
        success: function() {
            obj.hasClass("icon-star") ? obj.removeClass("icon-star").addClass("icon-star-empty") : obj.removeClass("icon-star-empty").addClass("icon-star");
        }
    });
})

由于推文很多,我设置了Infinite Scroll Plugin。当我没有设置无限滚动时,AJAX 请求运行良好。但是当我设置时,这些 AJAX 请求不适用于通过无限滚动加载的推文。我的意思是,当我单击通过无限滚动加载的推文的收藏按钮时,它们不会向服务器发送 AJAX 请求。但是 AJAX 请求适用于通过默认 HTML 而不是无限滚动加载的推文。

所以我的问题是我该如何解决这个问题?如何为通过 Infinite Scroll 加载的推文发送 AJAX 请求?

提前致谢。

4

1 回答 1

1

$('selector').on('event', callback)只为处理选择器时存在的元素绑定事件。但是,无限滚动代码稍后会加载新元素,因此不会为它们绑定任何事件。

解决方案是使用委托:

$('selector').on('click', 'i', function() {
    // do stuff
});

selector需要是包含所有(动态添加的)元素的父i元素。

于 2012-08-28T02:16:57.100 回答