跳转到下一节 - Jquery

时间:2013-02-06 23:59:38

标签: jquery navigation scroll

我正在水平布局中工作,并尝试在点击锚点时使用jquery,在html部分中导航。所以当点击跳转到下一部分时。

我看到一些例子在垂直方向做同样的事情!

HTML代码:

<div id="main">
    <div id="nav">
        <a id="prev" class="prev"> prev </a>
            <a id="next" class="next"> next </a>
        </div>
        <div class="content-container">
        <div class="content">
            <section id="about" class="panel">

                <p>About content</p>

            </section><!-- end about -->

            <section id="event" class="panel">

                <p>Event content</p>                

            </section><!-- end event -->

            <section id="services" class="panel">

                <p>Services content</p>

            </section><!-- end services -->

        </div><!-- end content -->

    </div><!-- end content-container -->
</div><!-- end main -->

JS代码

<script src="jquery-1.6.min.js"></script>
<script type="text/javascript">

    function scrollToPosition(element) {
            if (element !== undefined) {
                $("#main.content-container").scrollTo(element, 700, {
                    margin: true
                });
            }
    }

    $(function() {

            var posts = $('.panel');
        var position = 0; //Start Position
            var next = $('#next');
            var prev = $('#prev').hide();

            next.click(function(evt) {

                prev.show();
                scrollToPosition(posts[position += 1]);
                if (position === posts.length - 1) {
                        next.hide();
                }
            });

            prev.click(function(evt) {
                next.show();
                scrollToPosition(posts[position -= 1]);
                if (position === 0) {
                        prev.hide();
                }
            });

    });
</script>

我做错了什么?

1 个答案:

答案 0 :(得分:1)

您使用的方法scrollTo不是jQuery方法,而是插件方法。您没有包含任何插件,因此代码会在浏览器控制台中抛出错误而不执行任何操作。

在加载jQuery.js之后和代码之前包含插件文件。

否则,如果不在工作中看到你的CSS,很难说出你可能遇到的其他问题。