我有一个带有导航栏的网页,最初位于页面顶部下方 75px 左右。我编写了一个脚本,当导航栏到达浏览器窗口的顶部时,它会将导航栏固定到浏览器窗口的顶部。这在 safari/chrome 中运行良好,但在其他浏览器中不会触发效果。该栏永远不会切换到其固定模式。我是 html/css/javascript 的新手,所以问题可能很简单。这是代码:
<head>
<link rel="stylesheet" href="foo_css.css" />
<script type="text/javascript">
function window_onload() {
window.addEventListener("scroll",navbar_reset_top,false);
}
var navbar_top=75;
function navbar_reset_top() {
var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;
if(scrollTop>navbar_top&&nav.className==="navbar_absolute") {
document.getElementById("nav").className="navbar_fixed";
}
else if(scrollTop<navbar_top&&nav.className==="navbar_fixed") {
document.getElementById("nav").className="navbar_absolute";
}
}
</script>
</head>
<body onload="javascript:window_onload();">
<div id="nav" class="navbar_absolute">
<ul>
这就是我认为的所有相关CSS:
#nav.navbar_fixed {
position:fixed;
top:0px;
}
#nav.navbar_absolute {
position:absolute;
top:74px;
}