如何给引入的公共的当前导航添加样式???

Posted Candy-Yao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何给引入的公共的当前导航添加样式???相关的知识,希望对你有一定的参考价值。

因为头部是公共的,所以无法通过添加类的方式控制当前选中的类的颜色等样式。我们只能通过其他方法解决。

1、原理:首先找到当前a,然后循环判断,如果浏览器地址栏地址和a的href相等,就说明当前导航找到,添加定义的类。

2、代码

$(document).ready(function() {
  var mynav = $(‘.navbar-nav>li‘).find(‘a‘); //寻找导航的a元素
  for(var i = 0; i < mynav.length; i++) {  //循环遍历
    var links = mynav[i].getAttribute(‘href‘); //取出每个链接的href属性的值     var myurl = document.location.href; //取出当前窗口的链接     if(myurl.indexOf(links) != -1) { //判断浏览器地址是否等于当前a元素的href属性       mynav[i].className = "nav-hover"; //添加类     }   } })

3、详解indexof方法

  indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。

  如果要检索的字符串值没有出现,则该方法返回 -1。

注意:indexOf() 方法对大小写敏感!

以上是关于如何给引入的公共的当前导航添加样式???的主要内容,如果未能解决你的问题,请参考以下文章

head标签怎么给多个html引用

vue3单页面引入公共的css,加了scoped但无法加deep,导致样式无法穿透,如何解决?

给当前页或者跳转后页面的导航栏添加选中样式

JQ 遍历元素并给相应元素增加class

thymeleaf引入公共页面的某个片段

vue修改当前页样式不影响公共样式的方法