CSS 导航背景颜色仅在滚动到第一部分标签时更改

标签 css bootstrap-4

我正在尝试使用 Bootstrap 框架将导航栏背景颜色从透明更改为白色。当我使用 navbar-shrink 类稍微滚动时,它目前正在工作。但是,我只想在导航栏缩小时不立即到达第一部分标签后,将导航栏颜色从透明更改为白色...

#mainNav.navbar-shrink {
    border-bottom: 1px solid rgba(33,37,41,.1);
    background-color: #fff;
}

.container {
    background-color: grey;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js"></script>

<nav class="navbar navbar-expand-lg navbar-light fixed-top" id="mainNav">
    <div class="container">
        <button class="navbar-toggler navbar-toggler-right" type="button" data-toggle="collapse" data-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation">
            <span class="navbar-toggler-icon"></span>
        </button>
        <div class="collapse navbar-collapse" id="navbarResponsive">
            <ul class="navbar-nav ml-auto">
                <li class="nav-item">
                    <a class="nav-link js-scroll-trigger selected" href="#about">About</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link js-scroll-trigger" href="#services">Services</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link js-scroll-trigger" href="#portfolio">Projects</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link js-scroll-trigger" href="#contact">Contact</a>
                </li>
            </ul>
        </div>
    </div>
</nav>

<section class="bg-primary first" id="about">
    <div class="container">
        <div class="row">
</section>

我希望背景颜色仅在我滚动到部分标记 (id = about) 时发生变化,而不是在导航栏缩小时发生变化

最佳答案

如果您使用 ScrollSpy 插件来处理更新事件导航链接,您可以使用以下解决方案。当滚动到 #about 部分时,这只会将导航栏变成白色。

$('[data-spy="scroll"]').on('activate.bs.scrollspy', function (e) {
  var tabId = $(e.target).find('a').attr("href");
  if(tabId == "#about"){
    $("#mainNav").css("background-color","#fff")
  }
})

关于CSS 导航背景颜色仅在滚动到第一部分标签时更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53731238/

相关文章:

css - firebug 布局面板中的这条红线是什么?

css - 水平 float div重叠

javascript - 在 Firefox 中禁用文本区域的缓存

html - 黑色透明滤镜的位置和宽度(CSS,bootstrap 4)

html - Bootstrap 4 复选框随着背景颜色的变化而改变大小

html - Bootstrap 4 - 卡片列中的响应卡片

javascript - 获取计算的 CSS 属性(例如 : width) after view is rendered using Marionette Backbone. js

jquery - 向图像的小部分添加悬停状态

html - 我的导航栏不会自行居中

html - Bootstrap 卡片垂直对齐