3

我在 Chrome 中收到此 JavaScript 错误:

RangeError:超出最大调用堆栈大小 [http://localhost:5545/assets/js/jquery.min.js:2]

通过此click活动:

$('.accept-answer-button').click(function() {
    var id = $(this).parent().parent().attr('id').replace('answer_', ''),
        b = this;
    if ($('.accepted').length > 0) $('.accepted').click();
    AP.AcceptAnswer(id, $(b));
});​

的代码AP.AcceptAnswer()是:

AP.AcceptAnswer = function(a, o) {
    $.getJSON('/assets/ajax/accept-answer', {
        qid: qid,
        answer: a
    }, function(data) {
        if (data.success == true) {
            if (data.type == 'accepted') {
                var title = o.attr('data-unaccept-title').replace('{t}', data.time);
                o.addClass('accepted').attr('title', title);
            }
            else if (data.type == 'unaccepted') {
                var title = o.attr('data-accept-title').replace('{t}', data.time);
                o.removeClass('accepted').attr('title', title);
            }
        }
        else {
            alert(data.error);
        }
    });
}; // end AP.AcceptAnswer()​

$('.accepted').click();当用户想要接受另一个答案时,我只是不接受当前接受的答案(如果有的话)。

4

1 回答 1

2

您确定这些类.accepted.accept-answer-button没有指向同一个元素吗?如果他们是你这样做时递归触发点击事件:

$('.accepted').click(); 

如果$('.accepted').length > 0总是正确的。

于 2012-08-19T03:34:49.407 回答