• 每日分享!~ 如何解决获取卷曲高度的问题,document.body.scrollTop为什么在pc端拿不到值


    document.scrollingElement.scrollTop

    时间挺快的~ 又是四月的最后一天了!好了进入今天的正题了。你在做项目的时候,经常会不会搞混document.documentElement.scrollTop,和document.body.scrollTop呢? 在以前我也是经常搞混,为什么我监听了scroll是正确的?

    • 比如我在pc 端使用了document.body.scrollTop去获取当前的窗口的高度,始终是0,正在着急为什么是0??? 到底哪里错了。找了半天可能都不知道错在哪里了
    • 这个时候我们换上了document.documentElement.scrollTop, 就发现了可以拿到想要的值。

    先放一段代码吧!

           // console.log(window.pageXOffset)    
            var log = ''
            window.addEventListener('scroll',function(e){
                // console.log(document.documentElement.scrollTop)
                // ie 
                // console.log(document.body.scrollTop)
                //使用documnet.body.scrollTop. 无法监听到浏览器滚动的高度-
                // console.log(window.pageXOffset)
                log += '
    document.documentElement.scrollTop:'+ document.documentElement.scrollTop + '
    doucument.body.scrollTop是:'+ document.body.scrollTop;
                // result.innerHTMl = log
             
                var result = document.querySelector('#result')
                // console.log(result)
                result.innerHTML = log;
                // result.scrollTop = 9999;
    

    到底为什么会这样呢?

    • 因为在js中,document.documentElement.ScrollTop 是获取pc端的窗口高度
    • 如果使用 document.body.ScrollTop 是获取移动端的窗口高度

    如果想又要在pc端可以获取,又想在移动端获取那么可以把这两个代码都写一边就可以了但是呢,这样非常麻烦。

    这时候福音来了。 我们可以使用document.scrollingElement.scrollTop来解决这个问题了,推荐以后都要可以使用这个哦!!! 如果使用了这个获取窗口高度在移动端和pc端都可以拿到了

      document.addEventListener('scroll',function(){
                // console.log('ok')
                console.log(document.scrollingElement.scrollTop)
                // 设置scorllTop 的高度 
            })
    

    好了今天的分享就先到这里了!@~

  • 相关阅读:
    TestNg JAVA 自动化单元测试框架Demo
    Python Unittest 自动化单元测试框架Demo
    Mac 安装工具包brew
    Mac 终端提示You have not agreed to the Xcode license agreements
    查看 ios 真机调试log,导出log
    Python WxPython 的安装以及使用
    RTMP协议抓包详解
    流媒体协议地址获取 rtmp
    手游-放开那三国socket协议分析
    jquery.tochart.js
  • 原文地址:https://www.cnblogs.com/yaogengzhu/p/10798433.html
Copyright © 2020-2023  润新知