[英]How to fix bootstrap navbar to top with sidebar
我正在开发一个页面,其中既有sidebar
又有navbar
,我必须将导航栏固定到顶部,以便获得更好的用户体验。
问题
但是当我使用内置fixed-top
引导程序 class 它覆盖侧边栏时,我的navbar
在侧边栏的宽度之后开始,
所以我只想把它固定在顶部,这样滚动变得更容易
我的导航栏代码
<div>
<Navbar collapseOnSelect expand="lg" className="py-3 navbar_style">
<Navbar.Toggle aria-controls="responsive-navbar-nav" />
<Navbar.Collapse id="responsive-navbar-nav">
<Nav className="mr-auto"></Nav>
<Nav>
<Nav.Link href="#deets">Logout</Nav.Link>
</Nav>
</Navbar.Collapse>
</Navbar>
</div>
边条 CSS
.sidebar {
height: 100%;
width: 100px;
position: fixed;
top: 0;
left: 0;
transition: all 0.6s;
background: #ffffff 0% 0% no-repeat padding-box;
box-shadow: 0px 3px 6px #00000029;
opacity: 1;
}
我已经在沙箱中编写了最少的代码,我只想将导航栏修复到顶部而不覆盖我的侧边栏,请检查代码沙箱
Navbar{
z-index: 1000;
}
.sidebar {
z-index: 500;
}
它会正常工作的。
除非我误解了你的问题,否则应该这样做:
.navbar_style{
z-index: 0;
position: fixed;
top: 0;
left: 0;
right: 0;
}
如果我理解正确,header 导航的 position 与侧边栏导航重叠 - 这是因为这两个项目都是fixed
的。 将fixed-top
添加到导航栏后,您需要在侧边栏上使用margin-top
来添加缓冲区并将侧边栏向下推。 例子;
.sidebar {
height: 100%;
width: 233px;
position: fixed;
z-index: 500;
top: 0;
left: 0;
transition: all 0.6s;
background: rgb(167, 144, 144);
box-shadow: 0px 3px 6px #e0cccc29;
opacity: 1;
margin-top: 72px; /**<--add this**/
}
您必须将其调整为顶部导航栏的大小。 使用检查我可以看到它是72px
,所以我将侧边栏的margin-top
设置为相等。
改变位置
position:sticky
在侧边栏上
.sidebar {
position: sticky;
}
position position:fixed
到导航栏样式
.navbar_style {
position: fixed;
}
你可以加
粘顶
侧边栏和导航栏上的 class class
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.