如何像引导模式一样悬停导航栏时如何调暗网页?

时间:2018-05-29 19:50:35

标签: jquery css bootstrap-4

当模态打开时,是否可以使用Bootstrap在调暗页面时使用的相同步骤?

当我将鼠标悬停在自举导航栏上时,我希望它能够调暗页面 我不想让导航栏成为角色!

模态调暗如何工作?
我可以使用相同的CSS吗?

2 个答案:

答案 0 :(得分:1)

不,你不能使用现有的Bootstrap模态效果,因为这会使页面上的所有内容变暗,包括导航栏。

答案 1 :(得分:1)

您可以使用所有主流浏览器支持的纯CSS来完成此操作。

.navbar:hover+.nav-sibling {
  display: block;
  opacity: 0.5;
  background: rgba(0, 0, 0, 1);
  transition: opacity .15s linear;
}

.nav-sibling {
  position: fixed;
  display: none;
  overflow: hidden;
  outline: 0;
  /* equal to the navbar height */
  top: 56px;
  bottom: 0;
  left: 0;
  right: 0;
}
<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.1.1/css/bootstrap.css" rel="stylesheet" />
<nav class="navbar navbar-expand-lg navbar-light bg-light">
  <a class="navbar-brand" href="#">Navbar</a>
  <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
        <span class="navbar-toggler-icon"></span>
      </button>

  <div class="collapse navbar-collapse" id="navbarSupportedContent">
    <ul class="navbar-nav mr-auto">
      <li class="nav-item active">
        <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="#">Link</a>
      </li>
      <li class="nav-item dropdown">
        <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
              Dropdown
            </a>
        <div class="dropdown-menu" aria-labelledby="navbarDropdown">
          <a class="dropdown-item" href="#">Action</a>
          <a class="dropdown-item" href="#">Another action</a>
          <div class="dropdown-divider"></div>
          <a class="dropdown-item" href="#">Something else here</a>
        </div>
      </li>
      <li class="nav-item">
        <a class="nav-link disabled" href="#">Disabled</a>
      </li>
    </ul>
    <form class="form-inline my-2 my-lg-0">
      <input class="form-control mr-sm-2" type="search" placeholder="Search" aria-label="Search">
      <button class="btn btn-outline-success my-2 my-sm-0" type="submit">Search</button>
    </form>
  </div>
</nav>
<div class="nav-sibling">

</div>
<footer class=" container-fluid bg-dark text-white py-5">
  <div class="row">
    <div class="col-12">
      <h6>Lorem ipsum</h6>
      <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nullam eget sapien dolor. Nam aliquam augue ante, et sodales felis vulputate iaculis.</p>
    </div>
  </div>
</footer>

nav-sibling 与引导模式代码相同,但 top 属性除外。

更新

  

不透明度设置元素及其所有子元素的不透明度值;而RGBA仅为单个声明设置不透明度值。 - StackOverflow - opacity vs RGBA

最好使用01之间的数字代替alpha channel代替opacity。在下面的代码中,我使用了0.9

.navbar:hover+.nav-sibling {
  display: block;
  background-color: rgba(0, 0, 0, 0.9);
  transition: all .15s linear;
}