滚动到 DIV 元素的中心 - Angular 7

Posted

技术标签:

【中文标题】滚动到 DIV 元素的中心 - Angular 7【英文标题】:Scroll to the center of a DIV element - Angular 7 【发布时间】:2019-09-25 06:09:25 【问题描述】:

当某个函数被触发时,我想滚动到元素的 Y 和 X 中心。 我的 html 看起来像这样(我想滚动到#viewport 的中间):

 </div>
      <div #viewport class="document-view-port">
          <div #viewBox></div>
 </div>

在我的 TS 中,我正在导入这样的元素(这里我尝试找到 y 中心):

  @ViewChild('viewBox') viewBox: ElementRef;
  @ViewChild('viewport') viewport: ElementRef; 

我尝试提取此中心点进行滚动的最后一种方法是:

  zoomIn() 
    const elementRect = this.viewport.nativeElement.getBoundingClientRect();
    const absoluteElementTop = elementRect.top + window.pageYOffset;
    const middle = absoluteElementTop - (elementRect.height / 2);  
    this.viewport.nativeElement.scrollTo(0, middle)
  

我做不到,任何帮助将不胜感激

[编辑]

方法 scrollIntoView() 在我的代码中没有做任何事情。我想在不使用任何预定义函数的情况下找到这些坐标并滚动

【问题讨论】:

Scroll to element on click in Angular 4的可能重复 @JamieRees。它没有帮助。 scrollIntoView() 在我的情况下根本不做任何事情。 你应该使用window.scrollTo(0, middle);进行滚动 【参考方案1】:

你应该使用window.scrollTo(x, y)来实现滚动:

zoomIn() 
    const elementRect = this.viewport.nativeElement.getBoundingClientRect();
    const absoluteElementTop = elementRect.top + window.pageYOffset;
    const middle = absoluteElementTop - (elementRect.height / 2);  
    window.scrollTo(0, middle); // have a window object reference in your component
  

【讨论】:

感谢您的帮助,我尝试了代码,但它没有做任何事情middle = -225 @Igor.ro 你对 -225 有什么期望?那永远行不通。尝试调试为什么它是负值。该值必须为正才能起作用。

以上是关于滚动到 DIV 元素的中心 - Angular 7的主要内容,如果未能解决你的问题,请参考以下文章

Angular 2 @ViewChild 返回未定义

使用纯 Javascript 滚动到可滚动 DIV 内的元素

使用纯 Javascript 滚动到可滚动 DIV 内的元素

面临滚动精确元素并将数据添加到窗口滚动的 div 的问题

滚动到水平div中的元素

动态页面的操作(滚动屏幕到指定元素位置)和DIV滚动条滚动