最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - jQuery - scroll down every x seconds, then scroll to the top - Stack Overflow

programmeradmin4浏览0评论

I have a scrollable div that I want to scroll down 50 pixels every X seconds. That's fine and working.

I also have a seperate function that scrolls the div back to the top when it reaches the bottom. Also fine; working.

Now, I need to bine the two so the scrolldown is ignored until we have scrolled to the top again.

I have a 'working' example here, as you'll see it has some pretty nutty behavior: /

window.setInterval(scrollit, 3000);

function scrollit() {
    $('#scroller').delay(2000).animate({ scrollTop: $("#scroller").scrollTop() + 50 }, 'slow');
}

$('#scroller').bind('scroll', function () {
    if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
        $('#scroller').delay(2000).animate({ scrollTop: 0 }, 1000);
    }
});

I have a scrollable div that I want to scroll down 50 pixels every X seconds. That's fine and working.

I also have a seperate function that scrolls the div back to the top when it reaches the bottom. Also fine; working.

Now, I need to bine the two so the scrolldown is ignored until we have scrolled to the top again.

I have a 'working' example here, as you'll see it has some pretty nutty behavior: http://jsfiddle/JVftf/

window.setInterval(scrollit, 3000);

function scrollit() {
    $('#scroller').delay(2000).animate({ scrollTop: $("#scroller").scrollTop() + 50 }, 'slow');
}

$('#scroller').bind('scroll', function () {
    if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
        $('#scroller').delay(2000).animate({ scrollTop: 0 }, 1000);
    }
});
Share Improve this question edited Oct 25, 2012 at 11:03 VisioN 145k34 gold badges287 silver badges289 bronze badges asked Oct 25, 2012 at 11:03 Alan ShortisAlan Shortis 1,1093 gold badges18 silver badges38 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 4

My version:

var scrollingUp = 0;

window.setInterval(scrollit, 3000);

function scrollit() {
    if(scrollingUp == 0) {
        $('#scroller').delay(2000).animate({ scrollTop: $("#scroller").scrollTop() + 50 }, 'slow');
    }
}

$('#scroller').bind('scroll', function () {
    $('#status').html(scrollingUp);

    if ($(this).scrollTop() + $(this).innerHeight() >= $(this)[0].scrollHeight) {
        scrollingUp = 1;      
        $('#scroller').delay(2000).animate({ scrollTop: 0 }, 1000, function() {
            scrollingUp = 0;    
        });
    }
});​

Demo: http://jsfiddle/EFmeK/

Btw, in your jsfiddle, it scrolls 60px instead of 50px, which I "fixed" in my example.

Try something like that : http://jsfiddle/JVftf/3/

window.setInterval(scrollit, 1000);

function scrollit() {
    console.log(($("#scroller").scrollTop() + $("#scroller").innerHeight()))
    console.log($("#scroller")[0].scrollHeight)

    if(($("#scroller").scrollTop() + $("#scroller").innerHeight()) >= $("#scroller")[0].scrollHeight)   
        $('#scroller').animate({ scrollTop: 0 }, 100).delay(900);  
    else   
        $('#scroller').animate({ scrollTop: $("#scroller").scrollTop() + 60 }, 'slow',function(){

    });
}
发布评论

评论列表(0)

  1. 暂无评论