3

如何使用 Javascript 查找元素的偏移客户端位置?(我假设可以用 BHO 或 Gecko/NPAPI 编写相同的代码)。

我面临的问题是找出元素偏移客户端位置的方法。并不总是给出正确的e.srcElement.offsetX/Y值(clientX/Y 也是如此)。在某些情况下我们还需要考虑父元素的滚动。

我们一般如何做到这一点?有一个简单的方法吗?

4

4 回答 4

4

请看下面的代码:

function getOffsetSum(elem) {
    var top=0, left=0;
    while(elem) {
        top = top + parseInt(elem.offsetTop);
        left = left + parseInt(elem.offsetLeft);
        elem = elem.offsetParent;
    }
    return {top: top, left: left};
}
于 2012-10-27T00:12:14.583 回答
3
function getElementTop ( Elem ) 
{
    var elem;

    if ( document.getElementById ) 
    {   
        elem = document.getElementById ( Elem );
    } 
    else if ( document.all ) 
    {
        elem = document.all[Elem];
    }           

    yPos = elem.offsetTop;
    tempEl = elem.offsetParent;

    while ( tempEl != null ) 
    {
        yPos += tempEl.offsetTop;
        tempEl = tempEl.offsetParent;
    }  

    return yPos;
}   


function getElementLeft ( Elem ) 
{
    var elem;

    if ( document.getElementById ) 
    {
        var elem = document.getElementById ( Elem );
    } 
    else if ( document.all )
    {
        var elem = document.all[Elem];
    }           

    xPos = elem.offsetLeft;
    tempEl = elem.offsetParent;         

    while ( tempEl != null ) 
    {
        xPos += tempEl.offsetLeft;
        tempEl = tempEl.offsetParent;
    }           
    return xPos;
}

将元素 id 传递给函数。

于 2009-09-11T06:55:40.103 回答
1

要包括滚动,请查看此 jQuery 事件侦听器以记录 scrollTop 和偏移量。

// Don't put this in the scroll event listener callback, or that will be unnecessarily performance intensive.
var offset = $("#id").offset().top;

$(window).bind("scroll", function() {

 console.log(
  $(window).scrollTop() + 
  offset
 );

});

要单独获得偏移量,

("#id").offset().top;
于 2012-07-26T03:44:08.283 回答
0

Orhun Alp Oral 答案的CoffeeScript 版本:

getOffset = (elem)->
    top = 0
    left = 0
    while elem
        top += parseInt(elem.offsetTop)
        left += parseInt(elem.offsetLeft)
        elem = elem.offsetParent
    {top, left}
于 2016-07-16T03:46:38.350 回答