vant-fork
Version:
Lightweight Mobile UI Components built on Vue
37 lines (32 loc) • 1.55 kB
JavaScript
import { isServer } from './';
export default {
// get nearest scroll element
getScrollEventTarget: function getScrollEventTarget(element, rootParent) {
if (rootParent === void 0) {
rootParent = window;
}
var currentNode = element; // bugfix, see http://w3help.org/zh-cn/causes/SD9013 and http://stackoverflow.com/questions/17016740/onscroll-function-is-not-working-for-chrome
while (currentNode && currentNode.tagName !== 'HTML' && currentNode.tagName !== 'BODY' && currentNode.nodeType === 1 && currentNode !== rootParent) {
var overflowY = this.getComputedStyle(currentNode).overflowY;
if (overflowY === 'scroll' || overflowY === 'auto') {
return currentNode;
}
currentNode = currentNode.parentNode;
}
return rootParent;
},
getScrollTop: function getScrollTop(element) {
return 'scrollTop' in element ? element.scrollTop : element.pageYOffset;
},
setScrollTop: function setScrollTop(element, value) {
'scrollTop' in element ? element.scrollTop = value : element.scrollTo(element.scrollX, value);
},
// get distance from element top to page top
getElementTop: function getElementTop(element) {
return (element === window ? 0 : element.getBoundingClientRect().top) + this.getScrollTop(window);
},
getVisibleHeight: function getVisibleHeight(element) {
return element === window ? element.innerHeight : element.getBoundingClientRect().height;
},
getComputedStyle: !isServer && document.defaultView.getComputedStyle.bind(document.defaultView)
};