仅当在视口中时Javascript滚动IntoView
P粉011684326
P粉011684326 2023-09-11 16:33:49
[CSS3讨论组]

我制作了一个模型(请注意,它使用间隔,因为它在视频播放时滚动到新文本行)。我正在使用带有块的scrollIntoView:'nearest'。

问题是,由于整个页面都有滚动,它仍然滚动页面。我只是希望它滚动到lines div 中的活动文本行(它不必在视图中)。因为如果我正在查看“video”div,它将继续向下滚动(这是不需要的行为)。

var text = document.querySelector('.text')


setInterval(function() {
  text.scrollIntoView({
    behavior: 'smooth',
    block: 'nearest'
  });

}, 3000)
.a {
  height: 200px;
}

.elem {
  position: relative;
}

.video {
  width: 200px;
  height: 400px;
  background: #ccc;
  margin-bottom: 100px;
}

.lines {
  overflow-y: auto;
  height:120px;
}
lorem ipsum dolir sit amet
Vestibulum nulla justo
Fusce egestas, est ut fringilla facilisis
Maecenas eu erat condimentum
Quisque risus
fames ac turpis egestas
lorem ipsum dolir sit amet
Vestibulum nulla justo
Fusce egestas, est ut fringilla facilisis
Maecenas eu erat condimentum
Quisque risus
fames ac turpis egestas

P粉011684326
P粉011684326

全部回复(1)
P粉691958181

正如您所发现的,scrollIntoView() 不适合您在此处尝试执行的操作 - 它会积极滚动多个视图窗格以尝试将您的元素放入视图中。

更合适的是父元素上的 element.scrollTo(..) (在本例中为 .lines)。您需要进行一些高度算术以使元素在视口中居中,但这相对简单:

var text = document.querySelector('.text')

setInterval(function() {
  const parent       = text.parentElement;
  const parentHeight = parent.clientHeight;
  
  const textTop      = text.offsetTop - parent.offsetTop;
  const textMiddle   = textTop + text.offsetHeight / 2;

  parent.scrollTo({ top: textMiddle - parentHeight / 2, behavior: "smooth" });
}, 3000)
.a {
  height: 200px;
}

.elem {
  position: relative;
}

.video {
  width: 200px;
  height: 400px;
  background: #ccc;
  margin-bottom: 100px;
}

.lines {
  overflow-y: auto;
  height:120px;
}

.text {
  background: yellow;
}
<div class="a"></div>


<div class="elem">
  <div class="video"></div>


  <div class="lines">
    <div>lorem ipsum dolir sit amet</div>
    <div>Vestibulum nulla justo</div>
    <div>Fusce egestas, est ut fringilla facilisis</div>
    <div>Maecenas eu erat condimentum </div>
    <div>Quisque risus</div>
    <div>fames ac turpis egestas</div>
    <div>lorem ipsum dolir sit amet</div>
    <div>Vestibulum nulla justo</div>
    <div class="text">Fusce egestas, est ut fringilla facilisis</div>
    <div>Maecenas eu erat condimentum </div>
    <div>Quisque risus</div>
    <div>fames ac turpis egestas</div>

  </div>


</div>

<div class="a"></div>
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号