首頁  >  文章  >  web前端  >  js 取得元素在頁面上的偏移量的方法總結_javascript技巧

js 取得元素在頁面上的偏移量的方法總結_javascript技巧

WBOY
WBOY原創
2016-05-16 16:04:481355瀏覽

使用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()方法。

以上所述就是本文的全部內容了,希望能夠對大家學習javascript有幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn