使用 Element.scrollIntoView() 的行为



我正在使用Element.scrollIntoView() .滚动正在工作,但它同时破坏了我整个页面的布局。以下是演示:

* {
  margin: 0;
  padding: 0;
}
html, body {
  width: 100%;
  height: 100%;
}
.content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: lightgray;
}
ul {
  position: absolute;
  width: 100%;
  height: 300px;
  left: 0;
  bottom: 0;
  background-color: gray;
  overflow-y: scroll;
}
li {
  list-style: none;
}
#div {
  position: absolute;
  width: 100%;
  height: 300px;
  left: 0;
  bottom: -300px;
  background-color: darkgray;
}
button {
  position: absolute;
  right: 0;
  bottom: 0;
}
<div class=content>
  <!-- it's the ul to scroll, staying at the bottom of the page -->
  <ul>
    <li id=li>abc</li>
    <li>def</li>
  </ul>
  <!-- it's the div hidden under the bottom edge of the page -->
  <div id=div>i should stay hidden.</div>
  <button onclick=li.scrollIntoView();>scrollIntoView</button>
</div>

我在页面的底部边缘下隐藏了一个<div>。当我scrollIntoView <ul>的第一<li>时,隐藏的<div>被拉了出来。不仅是<div>,整个页面的内容都被拉高到300px。

我希望它只需将<li>滚动到<ul>的视图中即可。为什么会影响整个页面的布局?

我想我自己找到了答案。看到这个答案。这是关于锚的,但我认为scrollIntoView内部共享相同的机制。

浏览器将尽力确保元素可见。当它位于容器中时,它将首先将容器滚动到可见性最好的位置,以便将内容物拉起。

相关内容

  • 没有找到相关文章

最新更新