0

我目前正在建立一个投资组合网站,以展示我在大学期间所做的一些工作,并确定了单页设计。我希望网站做的是当您向下滚动并“输入”各个部分时,导航栏下方的向下箭头将水平滑过(作为动画)到当前活动部分/导航项下方。

我尝试了什么?老实说,没什么。我不是在寻找答案,虽然那很好,但我只需要一个起点。主要问题是我真的不知道如何将它“捕捉”到每个列表项下方,以便它完全位于文本的中心并满足不同的显示分辨率。

HTML

  <div id="header">
        <div class="topbar">
        </div>
        <div class="headbar">
            <nav>
                <div class="wrapper">
                    <ul>
                        <li><a href="#home">Home</a></li>
                        <li><a href="#about">About</a></li>
                        <li><a href="#work">Projects</a></li>
                        <li><a href="#contact">Contact</a></li>
                        <li><a href="#">Blog</a></li>
                    </ul>
                </div>
            </nav>
        </div>
        <div class="shadow">
        </div>
        <div class="current"></div>
    </div>

CSS

.wrapper {
width: 920px;
margin: 0 auto;
}

#header {
position: fixed;
width: 100%;
}

#header .topbar {
height: 10px;
background-color: #386c93;
}

#header .headbar {
height: 60px;
background: #f2f2f2;
background: url();
background: -moz-linear-gradient(top, #ffffff 0%, #f2f2f2 100%, #cbebff 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#f2f2f2), color-stop(100%,#cbebff));
background: -webkit-linear-gradient(top, #ffffff 0%,#f2f2f2 100%,#cbebff 100%);
background: -o-linear-gradient(top, #ffffff 0%,#f2f2f2 100%,#cbebff 100%);
background: -ms-linear-gradient(top, #ffffff 0%,#f2f2f2 100%,#cbebff 100%);
background: linear-gradient(to bottom, #ffffff 0%,#f2f2f2 100%,#cbebff 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#cbebff',GradientType=0 );
border-bottom: 1px solid #9b9999;
}

#header .shadow {
height: 17px;
background-image: url('shadow.png');
background-repeat: none;
background-position: center;
}

#header a {
color: #5c5959;
text-decoration: none;
}

#header a:hover {
color: #0092ff;
}

#header .current {
background-image: url('nav-pointer.PNG');
height: 19px;
width: 22px;
margin-top: -18px;
margin-left: 715px;
}

#header ul{
padding-top: 20px;
text-align: center;
list-style: none;
}

#header li {
font-size: 16px;
//float: left;
display: inline;
color: #5c5959;
padding: 30px;
}

我创建了一个 JSFiddle 只是为了让每个人的生活更轻松 - http://jsfiddle.net/GW6CG/2/ - 如果 CSS 有点乱,我很抱歉,我打算在某个时候清理它。

或者,您可以在此处查看该网站:http: //www.jonline.me.uk/dev/

非常感谢您的宝贵时间!

4

2 回答 2

2

从头开始创建此功能是没有意义的。已经创建了许多插件来实现这一点。一个是scrollit.js

此外,如果您想在滚动时添加放屁声,请查看fartscroll.js

希望我有所帮助。

于 2013-09-25T16:45:11.267 回答
1

我前段时间写了一些东西,你可以很容易地把它用作骨架:http: //jsfiddle.net/LYqVk/2/

JQuery 看起来像这样:

$('a[href*=#]').click(function (e) {
    e.preventDefault();

    var id = $(this).attr('href');
    var scrollTo = $(id).offset().top;

    $('html,body').animate({
        'scrollTop': scrollTo
    }, 500);
});

$(document).scroll(function () {
    highlightSection();
});

function highlightSection() {
    // Where's the scroll at?
    var currentPosition = $(this).scrollTop();

    // Remove highlights from all
    $('a[href*=#]').removeClass('highlighted');

    // Loop over each section
    $('#content .section').each(function () {
        // Calculate the start and end position of the section
        var sectionStart = $(this).offset().top;
        var sectionEnd = sectionStart + $(this).height();

        // If the current scroll lies between the start and the end of this section
        if (currentPosition >= sectionStart  && currentPosition < sectionEnd) {
            // Highlight the corresponding anchors
            $('a[href=#' + $(this).attr('id') + ']').addClass('highlighted');
        }
    });
};

highlightSection();

仔细阅读代码中的注释,希望它们足够解释,但以防万一它们不是基本过程是这样的:

  1. 找出我们在页面上的位置 -.scrollTop()
  2. 循环.sections
  3. 如果当前位置位于部分的顶部和底部之间,那就是我们要突出显示的位置*

    • 在你的情况下,那将是一个箭头。
于 2013-09-25T16:45:11.613 回答