mirror of
https://github.com/tusen-ai/naive-ui.git
synced 2025-01-12 12:25:16 +08:00
32 lines
877 B
JavaScript
32 lines
877 B
JavaScript
|
import getStyleComputedProperty from './getStyleComputedProperty'
|
||
|
import getParentNode from './getParentNode'
|
||
|
|
||
|
/**
|
||
|
* Returns the scrolling parent of the given element
|
||
|
* @method
|
||
|
* @param {Element} element
|
||
|
* @returns {Element} scroll parent
|
||
|
*/
|
||
|
export default function getScrollParent (element) {
|
||
|
// Return body, `getScroll` will take care to get the correct `scrollTop` from it
|
||
|
if (!element) {
|
||
|
return document.body
|
||
|
}
|
||
|
|
||
|
switch (element.nodeName) {
|
||
|
case 'HTML':
|
||
|
case 'BODY':
|
||
|
return element.ownerDocument.body
|
||
|
case '#document':
|
||
|
return element.body
|
||
|
}
|
||
|
|
||
|
// Firefox want us to check `-x` and `-y` variations as well
|
||
|
const { overflow, overflowX, overflowY } = getStyleComputedProperty(element)
|
||
|
if (/(auto|scroll|overlay)/.test(overflow + overflowY + overflowX)) {
|
||
|
return element
|
||
|
}
|
||
|
|
||
|
return getScrollParent(getParentNode(element))
|
||
|
}
|