码迷,mamicode.com
首页 > 其他好文 > 详细

让DOM元素自动滚到视野内ScrollIntoView

时间:2019-07-05 19:35:58      阅读:486      评论:0      收藏:0      [点我收藏+]

标签:pre   element   方法   hub   scrolltop   inter   fse   http   ssi   

概述

项目中需要把一个DOM元素自动滚动到视野内,百思不得其解,最后再element库里面发现了这个方法,记录下来供以后开发时参考,相信对其他人也有用。
参考资料:element scroll-into-view.js

代码

代码如下:

/* eslint-disable no-param-reassign */
export default function scrollIntoView(container, selected) {
  if (!selected) {
    container.scrollTop = 0;
    return;
  }

  const offsetParents = [];
  let pointer = selected.offsetParent;
  while (pointer && container !== pointer && container.contains(pointer)) {
    offsetParents.push(pointer);
    pointer = pointer.offsetParent;
  }
  const top = selected.offsetTop + offsetParents.reduce((prev, curr) => (prev + curr.offsetTop), 0);
  const bottom = top + selected.offsetHeight;
  const viewRectTop = container.scrollTop;
  const viewRectBottom = viewRectTop + container.clientHeight;

  if (top < viewRectTop) {
    container.scrollTop = top;
  } else if (bottom > viewRectBottom) {
    container.scrollTop = bottom - container.clientHeight;
  }
}

让DOM元素自动滚到视野内ScrollIntoView

标签:pre   element   方法   hub   scrolltop   inter   fse   http   ssi   

原文地址:https://www.cnblogs.com/yangzhou33/p/11140139.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!