css - 防止 100vw 在伪中创建水平滚动

标签 css width scrollbar viewport

有时在 wrapped by width div 中需要将元素背景设置为全宽,所以我将其设置为伪元素,但是 descktop 浏览器,当页面为长高度时,将垂直滚动条添加 16px 到视口(viewport),所以我计算它 通过计算(见下文)。

这里是 Example

HTML:

<div class="wrapped">
 <h1>100vw background in wrapped</h1>
 <div class="fullbg">
  some body text, images, etc here
 </div>
</div>

CSS

html, body {    margin: 0;      padding: 0;    }
body {     height: 100%;     width: 100%;    }
div {      position: relative;   }
*,*:before,*:after {      box-sizing: border-box;
 -moz-box-sizing: border-box;     -webkit-box-sizing: border-box;
}

.wrapped {
 width: 70%;
 margin: 0 auto;
 height: 150vh; /* simulate long heigh */
}
.fullbg {
 height: 5em;
/* some styles here*/
}

.fullbg:before {
 content: "";
 bottom: 0;
 display: block;
 background: rgba(85, 144, 169, 0.7);
 position: absolute;
 width: 100vw;
 right: 50%;
 margin-right: -50vw;                /* work for short page or mobile browser*/
 margin-right: calc( -50vw + 8px );  /* work for desctop long page  */ 
 top: 0;
 z-index: -1;
}

我看了答案

和其他问题, 但没有为此找到真正真正的通用 css 解决方案

作为临时解决方案可能是一个 js,比如 this :

var scrollbarWidth = ($(document).width() - window.innerWidth);

但我认为这不是最好的解决方案,考虑到滚动宽度可能会有所不同,现在我不知道如何将它与伪一起使用。

附言。没有人溢出:隐藏!

最佳答案

滚动条可以专门针对。

检查这个在 chrome 和 safari 中的修复

http://codepen.io/anon/pen/dXgmbZ

关键 CSS:

.element::-webkit-scrollbar { 
width: 0 !important;
}`

codepen 只是您使用 chrome 修复程序的示例。如果您想查看更强大的解决方案,请查看此 JSFiddle:
http://jsfiddle.net/E78q3/

这背后的想法只是用absolute定位剪掉滚动条并隐藏container/wrapper overflow。简单,聪明,但有效。

延伸阅读:
https://blogs.msdn.microsoft.com/kurlak/2013/11/03/hiding-vertical-scrollbars-with-pure-css-in-chrome-ie-6-firefox-opera-and-safari/

关于css - 防止 100vw 在伪中创建水平滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38783877/

相关文章:

JavaFX 仅将阴影投影到一侧

vb.net - 上下文菜单 strip 宽度

html - 允许父 div 被一些 child 拉伸(stretch),但不能被其他 child 拉伸(stretch)

javascript - jQuery - 锁定滚动条并防止页面跳转到顶部?

html - 根据视口(viewport)调整大小的 CSS 色带

CSS 打印样式表 - 示例

html - Bootstrap 网格垂直而不是水平

css - 2 列流体宽度 100% 高度?

c# - 列表框水平滚动条未正确更新

javascript - 禁用(不隐藏)浏览器滚动条