mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
37 lines
1.3 KiB
JavaScript
37 lines
1.3 KiB
JavaScript
import { isServer } from '.';
|
|
|
|
export default {
|
|
// get nearest scroll element
|
|
getScrollEventTarget(element, rootParent = window) {
|
|
let node = element;
|
|
// bugfix, see http://w3help.org/zh-cn/causes/SD9013 and http://stackoverflow.com/questions/17016740/onscroll-function-is-not-working-for-chrome
|
|
while (node && node.tagName !== 'HTML' && node.tagName !== 'BODY' && node.nodeType === 1 && node !== rootParent) {
|
|
const { overflowY } = this.getComputedStyle(node);
|
|
if (overflowY === 'scroll' || overflowY === 'auto') {
|
|
return node;
|
|
}
|
|
node = node.parentNode;
|
|
}
|
|
return rootParent;
|
|
},
|
|
|
|
getScrollTop(element) {
|
|
return 'scrollTop' in element ? element.scrollTop : element.pageYOffset;
|
|
},
|
|
|
|
setScrollTop(element, value) {
|
|
'scrollTop' in element ? element.scrollTop = value : element.scrollTo(element.scrollX, value);
|
|
},
|
|
|
|
// get distance from element top to page top
|
|
getElementTop(element) {
|
|
return (element === window ? 0 : element.getBoundingClientRect().top) + this.getScrollTop(window);
|
|
},
|
|
|
|
getVisibleHeight(element) {
|
|
return element === window ? element.innerHeight : element.getBoundingClientRect().height;
|
|
},
|
|
|
|
getComputedStyle: !isServer && document.defaultView.getComputedStyle.bind(document.defaultView)
|
|
};
|