我有一个网站与中心对齐的DIV。现在,一些页面需要滚动,一些不需要。当我从一种类型移动到另一种类型时,滚动条的出现将页面移向一侧几个像素。有没有什么方法可以避免这种情况,而不显式地在每个页面上显示滚动条?


当前回答

我已经在我的一个网站上解决了这个问题,通过显式地在javascript中设置主体的宽度为视口大小减去滚动条的宽度。我使用这里记录的基于jQuery的函数来确定滚动条的宽度。

<body id="bodyid>

var bodyid = document.getElementById('bodyid');
bodyid.style.width = window.innerWidth - scrollbarWidth() + "px";

其他回答

将可滚动元素的内容包装到div中,并应用padding-left: calc(100vw - 100%);。

<body>
    <div style="padding-left: calc(100vw - 100%);">
        Some Content that is higher than the user's screen
    </div>
</body>

诀窍是100vw代表包括滚动条在内的视口的100%。如果减去100%,即没有滚动条的可用空间,则最终得到滚动条的宽度,如果不存在滚动条,则得到0。在左侧创建该宽度的填充将模拟第二个滚动条,将居中的内容移回右侧。

请注意,这只在可滚动元素使用页面的整个宽度时才有效,但在大多数情况下这应该没有问题,因为只有少数其他情况下,您有居中可滚动内容。

总结

我认为有三种方法——每一种都有自己的特点:

Markus T.提到的滚动条槽。 溢出:kunalkamble提到的覆盖 添加间距与calc(100vw - 100%)提到的Rapti

以下是《StackBlitz》的演示版本

按“Toggle height”可以看到内容的移动。

滚动条男孩

这是有限的支持,但通过@support媒体查询,我们可以使用这和overflow-y: scroll的组合:

html {
  overflow-y: scroll;
}

@supports (scrollbar-gutter: stable) {
  html {
    overflow-y: auto;
    scrollbar-gutter: stable;
  }
}

这样,内容就永远不会改变。

这个解决方案的“问题”是滚动条总是有一个固定的空间。

溢出:覆盖 有限的支持,它显然隐藏了它覆盖的任何东西。需要特别注意的是,确保没有重要的东西被隐藏(也包括缩放和文本大小的变化)。

可与滚动条槽结合使用:

html {
  overflow-y: scroll;
}

@supports (scrollbar-gutter: stable) {
  html {
    overflow-y: auto;
    scrollbar-gutter: stable;
  }
}

@supports (overflow-y: overlay) {
  html {
    overflow-y: overlay;
    scrollbar-gutter: auto;
  }
}

可以使用一些负边距和overflow-x: hidden,但在某些情况下,这有隐藏重要内容的风险。小屏幕,自定义字体/缩放大小,浏览器扩展等。

Calc (100vw - 100%)

这可以在RTL支持下完成,如下所示:

html[dir='ltr'] main {
  padding-left: calc(100vw - 100%);
}

html[dir='rtl'] main {
  padding-right: calc(100vw - 100%);
}

在本例中,<main>是居中内容的容器。

只要居中的容器小于<main>,这里的内容就不会移动。但一旦它是100%的容器填充将被引入。查看StackBlitz演示,点击“切换宽度”。

这种解决方案的“问题”是,您需要媒体查询来防止“小屏幕”上的填充,即使在小屏幕上(当滚动条应该可见时),也会发生一些移动,因为没有空间容纳100%的内容和滚动条。

结论 使用滚动条槽也许结合覆盖。如果你绝对不想要空空格,尝试使用媒体查询的calc解决方案。

与公认的答案相反,即使内容没有溢出屏幕,也建议在浏览器窗口上使用永久滚动条,我更喜欢使用:

html{
  height:101%;
}

这是因为如果内容溢出,滚动条的外观更有意义。

这个比这个更有意义。

像这样简单地设置容器元素的宽度就可以了

width: 100vw;

这将使该元素忽略滚动条,并与背景颜色或图像一起工作。

用这个来扩展答案:

body {
    width: calc(100vw - 17px);
}

一位评论者建议添加左填充以保持居中:

body {
    padding-left: 17px;
    width: calc(100vw - 17px);
}

但是如果你的内容比视口宽,事情看起来就不对了。为了解决这个问题,你可以使用媒体查询,像这样:

@media screen and (min-width: 1058px) {
    body {
        padding-left: 17px;
        width: calc(100vw - 17px);
    }
}

1058px =内容宽度+ 17 * 2

这让水平滚动条处理x溢出,并在视口足够宽以包含固定宽度的内容时保持居中内容