十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章将为大家详细讲解有关BootStrap如何实现响应式导航栏垂直平分和下拉列表的居中问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
我们拥有10多年网页设计和网站建设经验,从网站策划到网站制作,我们的网页设计师为您提供的解决方案。为企业提供做网站、成都网站设计、微信开发、微信小程序定制开发、手机网站开发、成都h5网站建设、等业务。无论您有什么样的网站设计或者设计方案要求,我们都将富于创造性的提供专业设计服务并满足您的需求。
在查看psd图的效果是导航栏的a是垂直平分的。
那么我可否通过固定a超链接的高度来实现垂直平分呢?
带着这种想法,我设定了如下属性。
#h-cell-1 a{ display:inline-block; height:97px; margin-left:32px; font-size:17.8px; text-decoration: none;color:white; }
为此怎么实现垂直居中呢?
第一点想到的是position定位了
既然要实现相对于a超链接的position,那么必须引入一个span盒子了。
然后增加
#h-cell-1 li{height:97px;} #h-cell-1 a{ display:inline-block; position:relative; width:40px; height:97px; margin-left:32px; border-bottom:2px solid #20B176; font-size:17.8px; text-decoration: none;color:white; } #h-cell-1 a span{width:40px;}
就可实现垂直居中了!
但另外一个问题又接着出现了,在galaxy5的小屏幕下,下拉菜单的li间距太大,不美观。
又该怎么办呢?
这个是在28号晚上想到方法的。灵感也是看了其他同学的日报。他们提到媒体查询。
好,什么是媒体查询。建议百度。这里不做介绍。
媒体查询是吧,好那么久好办了。
@media only screen and (max-width: 700px) { #h-cell-1 li{height:auto;} #h-cell-1 a{height:20px;width:100%;margin:0;padding:0;overflow:hidden;} #h-cell-1 a span{height:auto;} }
ok,完美。
但是还有问题啊!
图标,和按钮原本是不垂直居中的啊!那这个怎么搞!
他们不是都在navbar-header的盒子里吗?
那不能通过flex两端对齐来实现垂直吗?
试试看
加了个
.df-jcsbc{display:flex;justify-content: space-between;align-items: center;}
但是效果不理想啊!总体来说,.navbar-brand 和navbra-toggle实现了垂直居中。
那,怎么办呢?
我是直接弄
.navbar-header{position: relative;height:97px;} .navbar-brand{ padding:0; } .navbar-header img{position:absolute; left:20px;} .navbar-header button{position:absolute; margin:0; right:20px;}
padding和margin来使他们让出位置来的。
然后通过定位稍微调了点左右距离。
最后就可以实现垂直居中了。
关于“BootStrap如何实现响应式导航栏垂直平分和下拉列表的居中问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。