css3 滚动条出现 页面不跳动

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了css3 滚动条出现 页面不跳动相关的知识,希望对你有一定的参考价值。

.wrap-outer {
margin-left: calc(100vw - 100%);
}
 
.wrap-outer {
padding-left: calc(100vw - 100%);
}
 
首先,.wrap-outer指的是居中定宽主体的父级,如果没有,创建一个(使用主体也是可以实现类似效果,不过本着宽度分离原则,不推荐);
然后,calc是CSS3中的计算,IE10+浏览器支持,IE9浏览器基本支持(不能用在background-position上);
最后,100vw相对于浏览器的window.innerWidth,是浏览器的内部宽度,注意,滚动条宽度也计算在内!而100%是可用宽度,是不含滚动条的宽度。
于是,calc(100vw - 100%)就是浏览器滚动条的宽度大小(如果有,如果没有滚动条则是0)!左右都有一个滚动条宽度(或都是0)被占用,主体内容就可以永远居中浏览器啦,从而没有任何跳动!
 
上面CSS还是有一点瑕疵的,浏览器宽度比较小的时候,左侧留的白明显与右边多,说不定会显得有点傻。此时,可能需要做点响应式处理会更好一点:
@media screen and (min-width: 1150px) {
  .wrap-outer { 
    margin-left: calc(100vw - 100%);
  }
}  

以上是关于css3 滚动条出现 页面不跳动的主要内容,如果未能解决你的问题,请参考以下文章

overflow:auto 时页面滚动条出现时跳动

css如何令页面刚好等於浏览器窗口大小, 不出现滚动条?

CSS3动画-音符跳动导航条制作16

不常用但很重要的几条CSS3代码

解决滚动条加载出现的页面抖动

Vue ant-design select滚动条跳动