scrollTop = scrollHeight类而不是id

时间:2012-12-25 02:45:15

标签: javascript ajax

好的,这就是我想要使用的

$(".shouts").scrollTop = $(".shouts").scrollHeight;

我认为在使用类而不是id时这是正确的,但这不起作用,我认为这是因为上面的代码是

function refreshShouts() {
    var refreshRate = 5000; // time in milliseconds
    var cacheBuster = (new Date).getTime();
    $.ajax({
        type: "POST",
        dataType: "xml",
        url: "php/getShouts.php",
        data: {op: 'tick', time: cacheBuster},
        error: function() { alert('An error occured! Try again.'); },
        success: function(xml){
            if($('shout', xml).size() > 0) {
                $('shout', xml).each(function(id){
                    var nickname = $('nickname', this).text();
                    var message = $('message', this).text();
                    var date = $('date', this).text();
                    var cssClass = 'shoutRow1';
                    if((id%2)/10 == 0)
                        cssClass = 'shoutRow';
                    var shoutRow = '<div id="'+cssClass+'"><span id="nickname">'+nickname+' <span id="date">('+date+')</span>: </span><span id="shoutedMessage">'+message+'</span></div>';
                    if(id == 0)
                        $('#shoutsContainer').empty().removeClass().addClass('shouts').html(shoutRow);
                    else
                        $('#shoutsContainer').removeClass().addClass('shouts').append(shoutRow);
                });
            } else {
                $('#shoutStatus').empty().addClass('shoutError').html($('error', xml).text());
                $('#shoutsContainer').empty().removeClass().addClass('noShouts').html('Shouts will be displayed here!');
            }
            $(".shouts").scrollTop = $(".shouts").scrollHeight;
        }
    });
    setTimeout('refreshShouts()', refreshRate);
}

也许是因为它创造了它,我不确定..通常我正在使用div id而不是类,但我希望能让它发挥作用。

1 个答案:

答案 0 :(得分:2)

它适用于ID,因为只有一个。但是对于课程,它如何知道哪一个是哪个?

试试这个:

$(".shouts").each(function() {this.scrollTop = this.scrollHeight;});