国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

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

2019-11-20 12:42:51
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

使用js制作效果時(shí),我們常常要獲取某個(gè)元素在頁(yè)面上的偏移量(例如tip提示框功能)。而獲取偏移量可以直接獲取相對(duì)于document的偏移量,也可以獲取相對(duì)與視口的偏移量(viewpoint)加上頁(yè)面滾動(dòng)量(scroll)獲得。

1.獲取相對(duì)與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  }}

通過(guò)向上迭代offsetParent,可以計(jì)算出相對(duì)于document的偏移量,也就是相對(duì)與頁(yè)面的偏移量。

此方法的問(wèn)題:

1)對(duì)于使用表格和內(nèi)嵌框架布局的頁(yè)面,由于不同瀏覽器實(shí)現(xiàn)元素方式的差異,得到的結(jié)果就不精確了。

2)每次都需要一級(jí)一級(jí)向上查找offsetParent,效率太低。

2.獲取相對(duì)與視口的偏移量(viewpoint)加上頁(yè)面的滾動(dòng)量(scroll)

function getOffsetRect(ele){      var box=ele.getBoundingClientRect();      var body=document.body,        docElem=document.documentElement;      //獲取頁(yè)面的scrollTop,scrollLeft(兼容性寫(xiě)法)      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)      }    }

此方法直接通過(guò)getBoundingClientRect()方法獲得相對(duì)于視口的偏移量,加上頁(yè)面的滾動(dòng)量,減去clientTop,clientLeft (IE8及更低版本瀏覽器將(2,2)作為起點(diǎn)坐標(biāo),所以要將值減去起點(diǎn)坐標(biāo),其他瀏覽器都是已(0,0)作為起點(diǎn)坐標(biāo))。

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

3.兼容性寫(xiě)法

//獲取元素相對(duì)于頁(yè)面的偏移function getOffset(ele){  if(ele.getBoundingClientRect){    return getOffsetRect(ele);  }else{    return getOffsetSum(ele);  }}

對(duì)于支持getBoundingClientRect()方法的瀏覽器使用getOffsetRect()方法,不支持的則使用getOffsetSum()方法。

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 涿州市| 四子王旗| 衡南县| 汨罗市| 海原县| 林州市| 阿拉善盟| 永德县| 屏南县| 海城市| 临武县| 莱芜市| 太保市| 永新县| 广东省| 丰都县| 广河县| 武邑县| 东乌珠穆沁旗| 肇源县| 怀化市| 焦作市| 竹北市| 通渭县| 琼海市| 朝阳市| 晋中市| 防城港市| 斗六市| 台中县| 延长县| 奈曼旗| 汉沽区| 威宁| 罗定市| 赤峰市| 沂源县| 永德县| 阳原县| 达日县| 桦南县|