【问题标题】:CSS 100vh offset by headerCSS 100vh 按标题偏移
【发布时间】:2017-11-12 17:30:42
【问题描述】:

我这里有这支笔:https://codepen.io/anon/pen/wPdrod

如您所见(至少在 Chrome 和 Firefox 中),有 2 个垂直滚动条。应该只有内部的,因为标题应该保持静态。

造成这种情况的 CSS 是:

#app
{
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    height: 100vh;
}

尤其是 100vh 高度。这导致视口太高了 36px。这是标题高度。如果我这样做:

#app
{
    ...
    height: calc(100vh - 36px);
}

然后它工作得很好。我试图弄清楚为什么我首先需要这样做。这种布局导致 100vh 占标题高度的原因是什么?我觉得我不应该这样做,因为标题与其余元素一起位于布局 div 中。

【问题讨论】:

  • 您需要在此处发布您的标记,而不是可能会在明天消失并使您的问题和答案无用的代码笔。 minimal reproducible example
  • 我稍微更新了我的答案,试图让它更清楚。如果还有什么我可以澄清或调整的,请告诉我。
  • 由于我没有得到任何回复,我只是假设我的回答没有帮助,所以我删除了它。

标签: html css flexbox viewport-units


【解决方案1】:

#header#app 内,所以这是正常行为,特别是如果您的邻居 (#body) 有 height: 100%(高度是相对于父级设置的,所以它也是 100vh)。这就是显示第二个滚动条的原因。

实际上你可以做的是从#body 中删除高度。

【讨论】:

  • 感谢您的快速回答。如果我从身体上移开高度,那么标题会滚动到屏幕外。标题需要在顶部保持静态。内容区域应该有滚动条。
  • @Troncoso 在#header 中添加position:fixed
  • 你也可以尝试使用 height: calc(100% - 36px) in #body。
猜你喜欢
  • 1970-01-01
  • 2019-03-27
  • 1970-01-01
  • 1970-01-01
  • 2013-07-01
  • 2016-05-20
  • 1970-01-01
  • 1970-01-01
  • 2021-10-23
相关资源
最近更新 更多