bootstrap row 导致的页面出现滚动条?
我不懂为什么bootstrap要给.row设置一个
margin-right: -15px;
margin-left: -15px;
这样导致页面水平位置出现滚动条,如何在不影响全局的情况下消除呢?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
我不懂为什么bootstrap要给.row设置一个
margin-right: -15px;
margin-left: -15px;
这样导致页面水平位置出现滚动条,如何在不影响全局的情况下消除呢?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(6)
因为bootstrap栅格的正确用法是:
row(
.row
)必须位于container的内部,column(如.col-md-6
)必须位于row的内部。如果按照这样的用法,就没有问题了。这是一个类似齿轮啮合的搭配,有一篇精妙的文章The Subtle Magic Behind Why the Bootstrap 3 Grid Works讲解了这些边距的设计的意义。
我个人来看的话,bootstrap是认为栅格之间的确要有间距才美观,所以设置的吧。
简单粗暴?
Overflow:hidden;
如果不这样,列的间距就不好弄,会出现第一列和最后一列不能顶格。
这时候在回答是不是晚了。。。
应该是你把.container或者.row的padding和margin修改过导致原bootstrap的css样式被你的样式覆盖不能自适应。你可以找找看比如你想增加padding:50px 0;只为了增加上下的距离,但是却不知不觉把左右的padding改变了。
把row放到container里面, 就ok了. 或者简单粗暴用overflow:hidden.
第一种方案是把row放到.container里面,这也是官方推荐的,这也是row为什么要设置margin:-15px,是为了抵消掉container的padding,
第二种方案,在row外面包裹一层div,给这个div设置padding:0px 15px;从而抵消掉row的margin