代码拉取完成,页面将自动刷新
import isElement from './isElement'
import getScrollLeft from './getScrollLeft'
import getStyle from './getStyle'
/**
* 获取 DOM 节点预期所有父节点的横向滚动距离
* ========================================================================
* @method getScrollTotalLeft
* @return {Number}
*/
const getScrollTotalLeft = (() => {
const $root = window
let scrollX = []
return (el) => {
let $parent
if (!isElement(el)) {
return scrollX
}
$parent = el.parentNode
if (!$parent) {
return scrollX
}
if ($parent === $root.document) {
const $body = document.body || document.documentElement
const position = getScrollLeft($body)
const x = [...scrollX]
x.push(position.x)
scrollX = []
return x
}
if (
['scroll', 'auto'].indexOf(getStyle($parent, 'overflow')) !== -1 ||
['scroll', 'auto'].indexOf(getStyle($parent, 'overflow-x')) !== -1
) {
const position = getScrollLeft($parent)
scrollX.push(position.x)
}
return getScrollTotalLeft($parent)
}
})()
export default getScrollTotalLeft
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。