欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js 獲取元素在頁面上的偏移量的方法匯總

 更新時間:2015年04月13日 09:01:06   投稿:hebedich  
javascript可以通過四個屬性可以獲得元素的偏移量,分別是1、offsetHeight,2、offsetWidth,3、offsetLeft,4、offsetTop,今天我們就來具體談一下獲取頁面元素偏移量的最佳方法。

使用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)對于使用表格和內(nèi)嵌框架布局的頁面,由于不同瀏覽器實現(xiàn)元素方式的差異,得到的結(jié)果就不精確了。

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

以上所述就是本文的全部內(nèi)容了,希望能夠?qū)Υ蠹覍W(xué)習(xí)javascript有是幫助。

相關(guān)文章

  • JavaScript中的細節(jié)分析

    JavaScript中的細節(jié)分析

    高山登不上,不是因為體力不支,只因鞋里一粒。學(xué)習(xí)也是如此,因而有必要把JavaScript中常見的和與其它語言不同的那些細節(jié)學(xué)習(xí)一下
    2012-06-06
  • 如何在TypeScript中處理日期字符串

    如何在TypeScript中處理日期字符串

    這篇文章主要介紹了如何在TypeScript中處理日期字符串,主要通過輸入日期字符串來改善開發(fā)者的體驗并減少潛在的錯誤,下文實現(xiàn)操作的分享需要的小伙伴可以參考一下
    2022-04-04
  • 詳解小程序橫屏方案對比

    詳解小程序橫屏方案對比

    這篇文章主要介紹了小程序橫屏方案對比,實現(xiàn)橫屏的方案也有多種,但是每種方案都有一定的缺陷,恰巧最近也在橫屏方案上踩了不少坑,本文就一起來介紹一下吧
    2020-06-06
  • 基本DOM節(jié)點操作

    基本DOM節(jié)點操作

    本文主要介紹了基本DOM節(jié)點操作,具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • NodeJS的Promise的用法解析

    NodeJS的Promise的用法解析

    下面小編就為大家?guī)硪黄狽odeJS的Promise的用法解析。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考
    2016-05-05
  • javascript算法之?dāng)?shù)組反轉(zhuǎn)

    javascript算法之?dāng)?shù)組反轉(zhuǎn)

    這篇文章主要介紹了javascript算法之?dāng)?shù)組反轉(zhuǎn),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • IP地址輸入框

    IP地址輸入框

    IP地址輸入框...
    2006-08-08
  • JavaScript實現(xiàn)拖拽和縮放效果

    JavaScript實現(xiàn)拖拽和縮放效果

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)拖拽和縮放效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • js實現(xiàn)宇宙星空背景效果的方法

    js實現(xiàn)宇宙星空背景效果的方法

    這篇文章主要介紹了js實現(xiàn)宇宙星空背景效果的方法,實例分析了javascript中動畫效果的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • JS代碼如何獲取map的key

    JS代碼如何獲取map的key

    這篇文章主要介紹了JS代碼如何獲取map的key,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論