导航栏向左移动时超出页面内容的长度

Navbar exceeds the length of the page content when move to the left

我正在使用 react-bootstrap 构建导航栏,但遇到以下问题。

当我滚动到 top/right/bottom 或保持页面静止时,一切看起来都很好。

但是当我向左滚动时,内容的右侧出现白色space,导致导航栏超出主体长度。

这是我的脚本:

const HomePage = () => {
  return (
    <div id="homePageTitle">
        <h1>Home Page</h1>
    </div>
  )
}


class Header extends React.Component {
  render() {
    return (
        <div>
          <Navbar inverse collapseOnSelect id="navbar">
            <Navbar.Header>
              <Navbar.Brand>
                <p>Brand</p>
              </Navbar.Brand>
            <Navbar.Toggle />
            </Navbar.Header>
            <Navbar.Collapse>
              <Nav pullRight>
                <NavItem eventKey={1}>Home</NavItem>
                <NavItem eventKey={2}>Projects</NavItem>
                <NavItem eventKey={3}>Passions</NavItem>
                <NavItem eventKey={4}>Contact</NavItem>
              </Nav>
            </Navbar.Collapse>
          </Navbar>
          <HomePage />
        </div>
    )};
  }

这是我的 css:

/*---------Header----------*/
.navbar-brand {
    min-height: 100px;
}

.navbar.navbar-inverse{
    width: 100%;
    height: 100px;
    margin-bottom: 0;
    background-color: lightskyblue;
    border: lightskyblue;
    border-radius: 0;
    position: fixed;
    top: 0;
    transition: opacity 0.5s;
}

.navbar-right {
    margin-top: 30px;
    font-size: 18px;
} 

/*---------HomePage----------*/

#homePageTitle {
    padding-top: 80px;
    padding-bottom: 420px;
    width: 100%;
    text-align: center;
    background-color: lightcoral;
    margin: 0;
    color: #507e9a;
}

即使只是关于为什么会发生这种情况的线索,我们也非常感激!谢谢!

body 的默认边距为 8px。如果你想要白色space,那么添加相同的

margin: 0 8px;

到导航栏 class。或者您可以添加:

body{
    margin: 0;
}

这将完全删除白色 space。发生这种情况是因为 #homePageTitle 仍在文档流中,而导航栏 position: fixed 已从文档流中删除,因此不受正文边距的影响,因为它不再受其限制。

您可以通过添加来进一步了解这一点:

body{
    position:relative;
}

这会将 body 设置为要固定的导航栏的上下文,因此再次受到 body 边距的影响。如果您想保留边距,这可能是首选方法,因为您不需要在任何其他 position: fixed 元素上设置边距。

如果无法使用页面本身,很难确定,但我很确定这是您的问题。

我发现有人遇到了类似的问题,按照 post 中的建议通过禁用水平滚动解决了这个问题。这完美地解决了我的问题。