在div内部时,jQuery滚动无法正常工作

时间:2010-10-15 16:09:30

标签: jquery class html scroll

我创建了一个jQuery函数,它将一个类应用于一个段落,然后在单击一个按钮时滚动到该段落。当段落相对于文档时,它工作正常,但我希望滚动发生在div内。目前,滚动工作正常,它正确应用类,但它不会滚动到正确的段落。每次点击按钮时,它似乎都会滚动到一个随机的。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
<script type="text/javascript">
        $(function() {

                $('.down').click(function() {
                    $('.current + p').addClass('current');
                    if ($('p:last').hasClass('current')) {
                        $('p').removeClass('current');
                        $('p:last').addClass('current');
                        return false;                   
                    }
                    else {
                    $('.current:first').removeClass('current');
                    return false;
                    }
                });

                $('.up').click(function() {
                    $('.current').prev('p').addClass('current');
                    if ($('p:first').hasClass('current')) {
                        $('p').removeClass('current');
                        $('p:first').addClass('current');
                        return false;
                    }
                    else {
                    $('.current:last').removeClass('current');
                    return false;
                }
            });
            $('.down, .up').click(function() {
                $('.slider').animate({scrollTop: $(".current").offset().top},'slow');
            });
        });
</script>

<style type="text/css">
.slider {
position: relative;
background: #ccc;
overflow: scroll;
height: 100px;
}
.slider p {
position: relative;
}
.nav {
position: fixed;
left: 500px;
z-index: 10;
}

p {
height: 100px;
}
</style>

</head>

<body>

<div class="nav">
<a href="#" class="up">UP</a>
<a href="#" class="down">DOWN</a>
</div>

<br /><br />
<div class="slider">
<p class="current">This is the first paragraph</p>
<p>111111111111111111111111</p>
<p>222222222222222222222222</p>
<p>333333333333333333333333</p>
<p>44444444444444444444444444</p>
<p>This is the last paragraph</p>
</div>


</body>
</html>

要在工作时查看它,请将CSS中的“.slider”更改为height:1000px并且不会溢出。另外,请更改此行:

$('.slider').animate({scrollTop: $(".current").offset().top},'slow');

到此:

$('html,body').animate({scrollTop: $(".current").offset().top},'slow');

1 个答案:

答案 0 :(得分:0)

适当使用'this'关键字可能有所帮助。