document.documentElement.scrollTop(获取滚动条位置,超细)

document.documentElement.scrollTop(获取滚动条位置)
要获取当前页面的滚动条纵坐标位置,用:
document.documentElement.scrollTop;
而不是:
document.body.scrollTop;
js中每个载入浏览器的 HTML 文档都会成为 Document 对象
documentElement 对应的是 html 标签,而 body 对应的是 body 标签。
scrollTop() 方法返回或设置匹配元素的滚动条的垂直位置。

在标准w3c下,document.body.scrollTop恒为0,需要用document.documentElement.scrollTop来代替;

一般在定义时,代码如下:

    var scrollTop=document.documentElement.scrollTop||document.body.scrollTop;(||这个是定义时必须加的或者而不是定义时的另一种写法)

所以在编程的时候,请加上这样的判断
if (document.body && document.body.scrollTop && document.body.scrollLeft)
{
    top=document.body.scrollTop;
    left=document.body.scrollleft;   
}
if (document.documentElement && document.documentElement.scrollTop && document.documentElement.scrollLeft)
{
    top=document.documentElement.scrollTop;
    left=document.documentElement.scrollLeft;
}
 

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
document.documentElement.scrollTop为0的原因可能是因为在Vue封装组件后,常常是在组件里面继续轮滑,而document.documentElement.scrollTop拿到的是最外层浏览器的轮滑高度,所以一直是0。\[1\]解决这个问题的方法是将原来的document.body.scrollTop改为document.documentElement.scrollTop。\[2\]另外,为了兼容所有浏览器,可以封装一个函数来获取页面向上卷曲出去的距离,可以使用以下代码:top: window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0。\[3\]这样可以确保在不同浏览器中都能正确获取到页面向上卷曲出去的距离。 #### 引用[.reference_title] - *1* [vue js document.documentElement.scrollTop获取一直为0的解决方法](https://blog.csdn.net/daishaochen/article/details/126866645)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [document.documentElement.scrollTop为零](https://blog.csdn.net/minpad/article/details/89376485)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [document.body.scrollTop的值总为零的解决办法](https://blog.csdn.net/weixin_42929937/article/details/121332022)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值