如何解决滚动条scrollbar出现造成的页面宽度被挤压的问题?
页面滚动条造成宽度减小的场景很常见了,由于div块级元素的流动性,其宽度默认为100%的body宽度,但是当容器的高度超过视口宽度时候,页面就会出现滚动条,这个滚动条的宽度就会挤压body的可用宽度,也就是会挤压我们的容器的宽度,造成页面晃动的现象,很不友好,下面就来探讨下如何解决这个滚动条的问题。
页面滚动条造成宽度减小的场景很常见了,由于div
块级元素的流动性,其宽度默认为100%的body
宽度,但是当容器的高度超过视口宽度时候,页面就会出现滚动条,这个滚动条的宽度就会挤压body
的可用宽度,也就是会挤压我们的容器的宽度,造成页面晃动的现象,很不友好,下面就来探讨下如何解决这个滚动条的问题。
一、最原始的scroll方法
首先来讲下最原始的方法,其思想是既然在触发滚动条时候会挤压空间,那么直接在没有滚动条的时候也触发不就可以了么,也就是我们上面算宽度时候的设置:
html { overflow-y: scroll; }
这样不论什么时候都有滚动宽度占据空间,不存在挤压的问题了...但是这样做有点蠢,毕竟在不需要滚动条的时候也有那么个丑丑的条子放在右边。但是他的优点在于方便而且没有兼容性的问题,其实很多大网站有时候也就这样用了。。。
二、新属性overlay方法
chrome下overflow
有个新的属性值overlay
,这个属性简直就是为了这个问题而生,他和auto
有点像,但是区别就是在触发滚动条时候并不挤压空间,说得直白点就像是移动端的悬浮滚动条,唯一的区别就是不会像手机上那样自动出现自动消失了,滚动条会遮盖住容器17px的空间。眼见为实用下面代码看一下就知道。
高度还未触发滚动条时候:
* {
margin: 0;
padding: 0;
}
html {
overflow-y: overlay;
}
.container {
height: 200px;
padding: 17px;
background-color: #00b83f;
text-align: right;
}
<div class="container">
<h1>我是容器内容</h1>
</div>
三、利用vw和calc实现
因为100vw是window
的宽度,其实就是window.innerWidth
, 而容器的宽度100%就是除了滚动条的可用宽度,因此在没有滚动条时候calc(100% - 100vw)
就是0,触发滚动条时候其值为负的滚动条宽度,我们将其赋值给容器的margin-right
,即可巧妙补偿这个宽度的挤压,在滚动条存在的情况下容器宽度仍然占据整个视口的宽度。
* {
margin: 0;
padding: 0;
}
html {
overflow-y: auto;
overflow-x: hidden;
}
.container {
height: 2000px;
margin-right: calc(100% - 100vw);
padding: 17px;
background-color: #00b83f;
text-align: right;
}
效果如同方法二,很完美,并且兼容性还不错,起码高版本的ie和ff都没问题了。
四、张鑫旭大佬那里抄来的absolute方法
这个利用了绝对定位,保证了body的宽度一直保持完整空间。
html {
overflow-y: scroll; //这是为了兼容ie8,不支持:root, vw
}
:root {
overflow-y: auto;
overflow-x: hidden;
}
:root body {
position: absolute;
}
body {
width: 100vw;
overflow: hidden;
}
在一个普通的容器滚动条挤压怎么办?
面是针对浏览器视口的滚动条方案,但是假如在一个普通div
容器中也有如此的需求改怎么办呢?因此此时并没有像100vw这样的值直接获取容器的宽度,只能使用js的方法来检测计算然后再用margin-right
做补偿,原理都是一样的,但是我强烈不推荐也不喜欢用js来计算布局...因此在这种情况下勉强委屈下用上面的第一种方法了,如果是chrome下用第二种方法。
.wrap { overflow-y: scroll; overflow-y: overlay; }
当然你坚决不能忍的话也可以用js去算吧...本质也是一样的
更多推荐
所有评论(0)