js教程

JS原生代码实现导航高亮示例

我的站长站 2022-01-05 人阅读

HTML代码

<nav>
<ul>
<li><a class="nav active" href="#nav1">导航1</a></li>
<li><a class="nav" href="#nav2">导航2</a></li>
<li><a class="nav" href="#nav3">导航3</a></li>
<li><a class="nav" href="#nav4">导航4</a></li>
</ul>
</nav>

为每个导航写一个对应的正文页面:

<div id="nav1" class="section">这是页面1</div>
<div id="nav2" class="section">这是页面2</div>
<div id="nav3" class="section">这是页面3</div>
<div id="nav4" class="section">这是页面4</div>

CSS代码

*{margin:0px;} /*先清除浏览器默认外边距*/
nav{
position:fixed;
width:100%;
z-index:999;
margin-top:0px
} /*fixed固定导航,并设置为最高层,防止被后面的元素遮盖。*/
nav ul{
text-align:center;
height:45px;
line-height:45px;
background:#0B0B0B;
}
nav li,nav li a{
display:inline-block;
height:100%;
text-decoration:none;
color:#fff;
}
nav li a{padding:0 10px;}
nav li{margin:0 10px;}
a:hover, .active{color:#B6B6B6;} /*为鼠标悬浮的状态以及当前页面对应的导航设置不同的颜色*/

添加正文的CSS:

.section{
height:660px;
width:100%;
margin:10px auto;
background:#F5F5F5;
padding-top:60px;
box-sizing:border-box;
border:1px solid red;
text-align:center;
}

将box-sizing设为border-box,每个页面的整体高度即为原来设定的高度,后面用js计算页面高度时免去计算content、padding、margin的麻烦

js代码

首先获取所有的导航: 

var navs=document.getElementByClassName('nav');

定义导航的切换方法,即每次通过增加一个类名active来为其应用已经设定好的样式,这里有4个导航,所以需要给4个元素添加类名。

function reset(index){
for(var i=0;i<4;i++){
navs[i].className="nav"; //注意每次添加类名之前先清空之前设置的active,否则只要经过的页面,对应的导航都是高亮状态
}
navs[index].className += " active";
}

由于是根据当前页面和滚动条的高度关联,从而利用滚动条的当前高度来判断应该切换哪个导航,因此要获取两个值:当前页面距离文档顶部的高度,以及当前滚动条的高度。

写一个函数来根据id获取单个页面整体的高度height

function getHeight(id){
var elem=document.getElementById(id);
var height=parseInt(window.getComputedStyle(elem,null)['height']);
return height;
}

调用这个函数并累加得出每个页面距离文档顶部的距离(不是窗口)。由于总共4个导航对应4个页面,所以只需判断3个页面即可。

var t1=getHeight("nav1");
var t2=t1+getHeight("nav2");
var t3=t2+getHeight("nav3");

再写一个函数通过将当前滚轮高度和当前页面距离文档顶部的高度来作比较,判断应当切换到哪个导航。将页面的滚动事件绑定到这个函数,实时获取滚轮高度的值,实现导航样式的实时切换:

window.onscroll=function changeCss(){
  var t=document.documentElement.scrollTop || document.body.scrollTop; //获取当前页面滚动条的高度
  if (t<t1){
    reset(0); //当页面还处于第一页时,第一个导航亮起
  } else if (t<t2){
    reset(1); //当页面滚动到第二页时,第一个导航熄灭,第二个导航亮起
  } else if (t<t3){
    reset(2);
  } else{
    reset(3);
  }
}

完整示例代码

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>别踩白块</title>
<style>
  *{margin:0px;}
  nav{position:fixed;width:100%;z-index:999;} /*fixed固定导航,并设置为最高层,防止被后面的元素遮盖。*/
  nav ul{margin-top:0px;text-align:center;height:45px;line-height:45px;background:#0B0B0B;}
  nav li,nav li a{display:inline-block;height:100%; text-decoration:none;color:#fff;}
  nav li a{padding:0 10px;}
  nav li{margin:0 10px;}
  a:hover, .active{color:#B6B6B6;} /*为鼠标悬浮的状态以及当前页面对应的导航设置不同的颜色*/
  .section{height:660px;width:100%;margin:0px auto;background:#F5F5F5;padding-top:60px;box-sizing:border-box;border:1px solid red;text-align:center;}
</style>
</head>
<body>
  <nav>
    <ul>
      <li><a class="nav active" href="#nav1">导航1</a></li>
      <li><a class="nav" href="#nav2">导航2</a></li>
      <li><a class="nav" href="#nav3">导航3</a></li>
      <li><a class="nav" href="#nav4">导航4</a></li>
    </ul>
  </nav>
  <div id="nav1" class="section">这是页面1</div>
  <div id="nav2" class="section">这是页面2</div>
  <div id="nav3" class="section">这是页面3</div>
  <div id="nav4" class="section">这是页面4</div>
  <script>
    var navs=document.getElementsByClassName('nav');
    function reset(index){
      for(var i=0;i<4;i++){
        navs[i].className="nav"; //注意每次添加类名之前先清空之前设置的active,否则只要经过的页面,对应的导航都是高亮状态
      }
      navs[index].className += " active";
    }
    function getHeight(id){
      var elem=document.getElementById(id);
      var height=parseInt(window.getComputedStyle(elem,null)['height']); //计算渲染后的style值
      return height;
    }
    var t1=getHeight("nav1");
    var t2=t1+getHeight("nav2");
    var t3=t2+getHeight("nav3");
    window.onscroll=function changeCss(){
      var t=document.documentElement.scrollTop || document.body.scrollTop; //获取当前页面滚动条的高度
      if (t<t1){
        reset(0); //当页面还处于第一页时,第一个导航亮起
      } else if (t<t2){
        reset(1); //当页面滚动到第二页时,第一个导航熄灭,第二个导航亮起
      } else if (t<t3){
        reset(2);
      } else{
        reset(3);
      }
    }
</script>
</body>
</html>
相关推荐
  • js代码
  • js指定时间定时自动执行代码分享

    示例代码用的`setTimeout()`函数,在指定的时间后执行。代码非常的简单,获取当前时间和设定一个指定时间,指定时间减去当前时间就是定时的时间,如果定时器到期时等于0,就代表时间到了,就运行executeAtTime函数的方法。function executeAtTime() { console....

    js教程 40 6个月前
  • JS代码解除网页右键限制

    JS解除右键限制方法一javascript:(function () {function R(a) {ona = "on" + a;if (window.addEventListener){window.addEventListener(a, function (e) {for (var n = e.originalTarget; n; n = n.parentNode){n[ona] = null;}}, true);}window[o...

    js教程 171 3年前
  • 淘宝买家秀API+ajax代码

    淘宝买家秀API+ajax代码,用的是这个API,https://api.66mz8.com/api/rand.tbimg.php?format=jsonJSON返回格式,测试依旧可用。$(function(){ $.get('https://api.66mz8.com/api/rand.tbimg.php?format=json',function(data){ document.getElementB...

    js教程 713 3年前
最新更新
  • js截取字符串教程

    slice()方法接受两个参数,起始索引和结束索引(可选)。它返回从起始索引到结束索引(不包括结束索引)之间的子字符...

    js教程 2个月前
  • find findIndex indexOf索引选择器使用方法

    find使用方法find方法是ES6引入的一种数组方法,可以用来查找数组中符合条件的元素。语法是:array.find(callba...

    js教程 3个月前
  • js复制网页内容教程

    Async Clipboard API方法HTML5新增的方法,无需引入第三方插件,直接就可以复制内容。低版本的浏览器可能会不兼...

    js教程 3个月前
  • js获取字符长度函数分享

    js获取字符长度函数function objLen(str) { if (str == null) return 0; if (typeof str != "string") { ...

    js教程 3个月前
  • 网站LED跑马灯效果广告代码

    网站可以看到很多的论坛网站都会用到这种网站LED跑马灯效果,这种效果实现也很简单,分享给大家。LED跑马灯效果...

    js教程 4个月前