我遇到了一个问题,即按钮没有将我滚动到锚点的顶部,而是滚动到了该部分的太远(那是因为我的导航栏是固定的,并且与该部分重叠)。
我用边距和填充物固定了它,但是我觉得有一个更好,更简单的解决方案。 https://jsfiddle.net/HcJanni/2n9b0ohp/76/
我尝试了几个小时,但是找不到真正的完美解决方案,总有些问题,无法正常工作。
$(function() {
var shrinkHeader = 100;
$(window).scroll(function() {
var scroll = getCurrentScroll();
if (scroll >= shrinkHeader) {
$('#navbar').addClass('shrink');
} else {
$('#navbar').removeClass('shrink');
}
});
function getCurrentScroll() {
return window.pageYOffset || document.documentElement.scrollTop;
}
});
// JavaScript Document
$(document).ready(function() {
var navTop = $('#navbar').offset().top;
var navHeight = $('#navbar').height();
var windowH = $(window).height();
$('.section').height(windowH);
$(document).scroll(function() {
var st = $(this).scrollTop();
//for the nav bar:
if (st > navTop) {
$('#navbar').addClass('fix');
$('.section:eq(0)').css({
'margin-top': navHeight
}); //fix scrolling issue due to the fix nav bar
} else {
$('#navbar').removeClass('fix');
$('.section:eq(0)').css({
'margin-top': '0'
});
}
$('.section').each(function(index, element) {
if (st + navHeight > $(this).offset().top && st + navHeight <= $(this).offset().top + $(this).height()) {
$(this).addClass('active');
var id = $(this).attr('id');
$('a[href="#' + id + '"]').parent('li').addClass('active');
// or $('#nav li:eq('+index+')').addClass('active');
} else {
$(this).removeClass('active');
var id = $(this).attr('id');
$('a[href="#' + id + '"]').parent('li').removeClass('active');
//or $('#nav li:eq('+index+')').removeClass('active');
}
});
});
});
//
/* MAIN */
/* SECTION HOME */
#home {
height: 853px !important;
display: flex;
z-index: -1;
position: relative;
top: -128px;
padding-top: 128px;
}
#homebild {
width: 1280px;
height: 853px;
}
/* SECTION WIR-UEBER-UNS */
#wir-ueber-uns {
height: 853px !important;
display: flex;
top: -208px;
padding-top: 80px;
z-index: -2;
position: relative;
background-color: lightblue;
}
#wir-ueber-unsbild {
width: 1280px;
height: 853px;
}
/* SECTION AKTIONEN */
#aktionen {
height: 853px !important;
display: flex;
padding-top: 80px;
top: -288px;
z-index: -3;
position: relative;
background-color: darkblue;
}
#aktionenbild {
width: 1280px;
height: 853px;
}
/* SECTION TERMINVEREINBARUNG */
#terminvereinbarung {
height: 853px !important;
padding-top: 80px;
top: -368px;
display: flex;
z-index: -4;
position: relative;
background-color: red;
}
#terminvereinbarungbild {
width: 1280px;
height: 853px;
}
/* SECTION INFOS */
#infos {
height: 772px !important;
width: 1280px;
display: flex;
padding-top: 80px;
top: -448px;
z-index: -5;
position: relative;
background-color: darkblue;
}
/* MAIN ENDE */
<!DOCTYPE html>
<html>
<head>
<title>OptikTack</title>
<link href="style.css" rel="stylesheet" type="text/css">
<link href="https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap" rel="stylesheet">
</head>
<body>
<div id="container">
<div class="body">
<!-- NAVIGATION -->
<nav id="navbar">
<script class="cssdeck" src="//cdnjs.cloudflare.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script>
<script src="javascript/navbar fixed.js"></script>
<a href="#home" id="logo"><img src="https://i.postimg.cc/przxCGcx/Logo.png" class="logo"></a>
<ul>
<li class="hvr-sweep-to-top active"><a href="#home">Home</a></li>
<li class="hvr-sweep-to-top"><a href="#wir-ueber-uns">Wir über uns</a></li>
<li class="hvr-sweep-to-top"><a href="#aktionen">Aktionen</a></li>
<li class="hvr-sweep-to-top"><a href="#terminvereinbarung">Terminvereinbarung</a></li>
<li class="hvr-sweep-to-top"><a href="#infos">Infos</a></li>
</ul>
</nav>
<!-- NAVIGATION ENDE -->
<!-- MAIN -->
<div id="spacer"></div>
<!-- home section -->
<section id="home" class="section">
<div>
<img src="https://i.postimg.cc/tgk5cWmx/Bild-1.jpg" alt="Frau" id="homebild" width="1280px">
</div>
</section>
<!-- home section ende -->
<!-- wir-ueber-uns section -->
<section id="wir-ueber-uns" class="section">
<div>
<img src="https://i.postimg.cc/FH6RSxbF/Bild-2.jpg" width="1280px" id="wir-ueber-unsbild">
</div>
</section>
<!-- wir-ueber-uns section ende -->
<!-- aktionen section -->
<div id="reference"></div>
<section id="aktionen" class="section">
<div>
<img src="https://i.postimg.cc/k5P0L6qF/Bild-5.jpg" width="1280px" id="aktionenbild">
</div>
</section>
<!-- aktionen section ende -->
<!-- terminvereinbarung section -->
<section id="terminvereinbarung" class="section">
<div>
<img src="https://i.postimg.cc/6q8b8tBp/Bild-9.jpg" width="1280px" id="terminverinbarungbild">
</div>
</section>
<!-- terminvereinbarung section ende -->
<!-- infos section -->
<section id="infos" class="section">
<div>
<p>section 5</p>
</div>
</section>
<!-- infos section ende -->
<!-- MAIN ENDE -->
答案 0 :(得分:0)
我添加了
font-family: "Saira", "Roboto", Segoe UI, Helvetica Neue, Arial, sans-serif;
box-sizing: border-box;
}
,并将每个部分的top:
更改为-80px(因为导航栏的高度为80px)
这使它变得更简单
答案 1 :(得分:0)
您可以为所有这些锚添加一个类,从而为锚添加一个伪元素,并具有以下设置:
.your_anchor_class::before {
display: block;
content: " ";
margin-top: -80px;
height: 80px;
visibility: hidden;
pointer-events: none;
}
80px
和-80px
的值必须根据固定标头的高度进行调整,但这将创建与标头一样高的伪元素,然后为 后面的标头,然后将其相应的“主要”元素对齐在标头下。
看到小提琴后进行添加/编辑(评论后再编辑一次):
我之前不知道您不会直接“跳转”到锚点位置,但是有一个动画滚动脚本可以滚动到这些锚点,因此必须进行不同的处理,即更改脚本。
因此,我只更改了Javascript中的一件小东西(位于HTML代码的底部):我在animate
函数中添加了“-80”,该函数将(或减去)一个80px的偏移量添加到脚本动画滚动的位置。 (唯一的例外:如果链接锚为#home
,则没有偏移量,因为在这种情况下,页面必须一直向上滚动,因此if / else就是这样):
<!-- Smooth Scroll -->
<script>
$('a').click(function() {
var scrollziel = $(this).attr('href');
if(scrollziel == '#home') {
$('html, body').animate({
scrollTop: 0
}, 500);
return false;
} else {
$('html, body').animate({
scrollTop: $($(this).attr('href')).offset().top - 80
}, 500);
return false;
}
});
</script>
<!-- Smooth Scroll Ende -->
这似乎可以解决它,请看我的小提琴版本,只有一点点不同:https://jsfiddle.net/c1gjybtf/