type ScrollElement = HTMLElement | Window; // get nearest scroll element // http://w3help.org/zh-cn/causes/SD9013 // http://stackoverflow.com/questions/17016740/onscroll-function-is-not-working-for-chrome const overflowScrollReg = /scroll|auto/i; export function getScrollEventTarget(element: HTMLElement, rootParent: ScrollElement = window) { let node = element; while ( node && node.tagName !== 'HTML' && node.nodeType === 1 && node !== rootParent ) { const { overflowY } = window.getComputedStyle(node); if (overflowScrollReg.test(overflowY)) { if (node.tagName !== 'BODY') { return node; } // see: https://github.com/youzan/vant/issues/3823 const { overflowY: htmlOverflowY } = window.getComputedStyle(node.parentNode); if (overflowScrollReg.test(htmlOverflowY)) { return node; } } node = node.parentNode; } return rootParent; } export function getScrollTop(element: ScrollElement): number { return 'scrollTop' in element ? element.scrollTop : element.pageYOffset; } export function setScrollTop(element: ScrollElement, value: number) { 'scrollTop' in element ? (element.scrollTop = value) : element.scrollTo(element.scrollX, value); } export function getRootScrollTop(): number { return window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0; } export function setRootScrollTop(value: number) { setScrollTop(window, value); setScrollTop(document.body, value); } // get distance from element top to page top export function getElementTop(element: ScrollElement) { return ( (element === window ? 0 : (element).getBoundingClientRect().top) + getRootScrollTop() ); } export function getVisibleHeight(element: ScrollElement) { return element === window ? element.innerHeight : (element).getBoundingClientRect().height; }