zoukankan      html  css  js  c++  java
  • js 获取元素在页面上的偏移量的最佳方式

    使用js制作效果时,我们常常要获取某个元素在页面上的偏移量(例如tip提示框功能)。而获取偏移量可以直接获取相对于document的偏移量,也可以获取相对与视口的偏移量(viewpoint)加上页面滚动量(scroll)获得。

    1.获取相对与document的偏移量

    function getOffsetSum(ele){
        var top= 0,left=0;
        while(ele){
            top+=ele.offsetTop;
            left+=ele.offsetLeft;
            ele=ele.offsetParent;
        }
        return {
            top:top,
            left:left
        }
    }
    

    通过向上迭代offsetParent,可以计算出相对于document的偏移量,也就是相对与页面的偏移量。

    此方法的问题:

    1)对于使用表格和内嵌框架布局的页面,由于不同浏览器实现元素方式的差异,得到的结果就不精确了。

    2)每次都需要一级一级向上查找offsetParent,效率太低。

    2.获取相对与视口的偏移量(viewpoint)加上页面的滚动量(scroll)

    function getOffsetRect(ele){
                var box=ele.getBoundingClientRect();
                var body=document.body,
                    docElem=document.documentElement;
                //获取页面的scrollTop,scrollLeft(兼容性写法)
                var scrollTop=window.pageYOffset||docElem.scrollTop||body.scrollTop,
                    scrollLeft=window.pageXOffset||docElem.scrollLeft||body.scrollLeft;
                var clientTop=docElem.clientTop||body.clientTop,
                    clientLeft=docElem.clientLeft||body.clientLeft;
                var top=box.top+scrollTop-clientTop,
                    left=box.left+scrollLeft-clientLeft;
                return {
                    //Math.round 兼容火狐浏览器bug
                    top:Math.round(top),
                    left:Math.round(left)
                }
            }
    

    此方法直接通过getBoundingClientRect()方法获得相对于视口的偏移量,加上页面的滚动量,减去clientTop,clientLeft (IE8及更低版本浏览器将(2,2)作为起点坐标,所以要将值减去起点坐标,其他浏览器都是已(0,0)作为起点坐标)。

    getBoundingClientRect()方法支持IE,ff3+,safari4+,Orear9,5,Chrome.

    3.兼容性写法

    //获取元素相对于页面的偏移
    function getOffset(ele){
        if(ele.getBoundingClientRect){
            return getOffsetRect(ele);
        }else{
            return getOffsetSum(ele);
        }
    }
    

    对于支持getBoundingClientRect()方法的浏览器使用getOffsetRect()方法,不支持的则使用getOffsetSum()方法。

    参考:

    http://javascript.info/tutorial/coordinates#element-coordinates-by-offsetparent  

      

      

      

  • 相关阅读:
    Kafka 1.0.0集群安装
    java实现以docx格式导出
    基于java处理.docx格式的word合并
    基于java 合并.doc和docx格式的Word文件
    Docker版本Jenkins的使用
    Codeforces 1243 D 0-1 MST
    Public model for matrix
    Codeforces 1220 E Tourism
    Codeforces 1221 G Graph And Numbers
    Codeforces 1221 F Choose a Square
  • 原文地址:https://www.cnblogs.com/Tzhibin/p/4420537.html
Copyright © 2011-2022 走看看