如何创建:滚动时下滑导航栏

学习如何使用 CSS 和 JavaScript 在滚动时向下滑动导航栏。

亲自试一试

如何下滑导航栏

第一步 - 添加 HTML:

创建导航栏:

<div id="navbar">
  <a href="#home">Home</a>
  <a href="#news">News</a>
  <a href="#contact">Contact</a>
</div>

第二步 - 添加 CSS:

设置导航栏样式:

#navbar {
  background-color: #333; /* 黑色背景色 */
  position: fixed; /* 使其粘住/固定 */
  top: -50px; /* 将导航栏隐藏在顶视图之外 50px 处 */
  width: 100%; /* 全宽 */
  transition: top 0.3s; /* 向下(向上)滑动时的过渡效果 */
}

/* 设置导航栏链接的样式 */
#navbar a {
  float: left;
  display: block;
  color: white;
  text-align: center;
  padding: 15px;
  text-decoration: none;
}

#navbar a:hover {
  background-color: #ddd;
  color: black;
}

第三步 - 添加 JavaScript:

// 当用户从文档顶部向下滚动 20px 时,向下滑动导航栏
// 当用户滚动到页面顶部时,向上滑动导航栏(距顶部视图 50px)
window.onscroll = function() {scrollFunction()};

function scrollFunction() {
  if (document.body.scrollTop > 20 || document.documentElement.scrollTop > 20) {
    document.getElementById("navbar").style.top = "0";
  } else {
    document.getElementById("navbar").style.top = "-50px";
  }
}

亲自试一试