0
我有這個固定的錨鏈接菜單組成,它有滾動時的視覺變化。我怎樣才能通過點擊錨點並不僅僅通過滾動頁面來進行更改?當我避免滾動並直接使用錨鏈接時,視覺效果不會改變。希望你們能幫助我。製作滾動效果以及點擊以及
HTML
<div id="pointer">
<a href="#first"><span class="one"></span></a>
<a href="#second"><span class="two"></span></a>
<a href="#third"><span class="three"></span></a>
<a href="#fourth"><span class="four"></span></a>
<a href="#areaTest"><span class="five"></span></a>
</div>
CSS
body{background-color: #003333;}
#pointer{
position: fixed;
top: 50%;
left: 50px;
}
#pointer span{
display: block;
height: 13px;
width: 25px;
border-top-color: #999999;
border-top-style: solid;
border-top-width: 1px;
}
JS
$(function() {
$(window).on('wheel', function(e) {
var delta = e.originalEvent.deltaY;
var windowScrollTop = $(this).scrollTop();
if (delta > 0) {
//scroll-down
if(windowScrollTop > 0){
$(".one").css("border-top-color","#fff").animate({width: '50px'}, 100);
}
if(windowScrollTop > 350){
$(".two").css("border-top-color","#fff").animate({width: '50px'}, 100);
}
if(windowScrollTop > 750){
$(".three").css("border-top-color","#fff").animate({width: '50px'}, 100);
}
if(windowScrollTop > 1150){
$(".four").css("border-top-color","#fff").animate({width: '50px'}, 100);
}
if(windowScrollTop > 1500){
$(".one, .two, .three, .four, .five").css("border-top-color","#999999");
$(".five").animate({width: '50px'}, 100);
$("body").css('background-color', '#fff');
}
}
else {
//scroll-up
if(windowScrollTop < 350){
$(".two").css("border-top-color","#999999").animate({width: '25px'}, 100);
}
if(windowScrollTop < 750){
$(".three").css("border-top-color","#999999").animate({width: '25px'}, 100);
}
if(windowScrollTop < 1150){
$(".four").css("border-top-color","#999999").animate({width: '25px'}, 100);
}
if(windowScrollTop < 1500){
$(".one, .two, .three, .four, .five").css("border-top-color","#fff");
$(".five").animate({width: '25px'}, 100);
$("body").css('background-color', '#003333');
}
}
});
});
謝謝@Andrea!它工作真棒!如果可能的話,我只想問一件事。有沒有辦法讓用戶點擊錨鏈接時滾動更順暢? –
我可以通過$(「body」)使滾動更平滑。animate({scrollTop:$('#'+ targetId).offset()。top-200},「slow」);但現在它不會在滾動時將bgColor更改回灰色 –