日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JS获取元素在页面的位置

發布時間:2024/9/20 javascript 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JS获取元素在页面的位置 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JS獲取元素的offsetTop,offsetLeft等屬性
obj.clientWidth?//獲取元素的寬度(width+padding)
obj.clientHeight?//元素的高度
obj.offsetLeft?//元素相對于父元素的left
obj.offsetTop?//元素相對于父元素的top
obj.offsetWidth?//元素的寬度(width+padding+border)
obj.offsetHeight?//元素的高度

//獲取元素的縱坐標(相對于窗口)

  • function getTop(e){
  • var offset=e.offsetTop;
  • if(e.offsetParent!=null) offset+=getTop(e.offsetParent);
  • return offset;
  • }
  • //獲取元素的橫坐標(相對于窗口)

  • function getLeft(e){
  • var offset=e.offsetLeft;
  • if(e.offsetParent!=null) offset+=getLeft(e.offsetParent);
  • return offset;
  • }
  • 上面的方法無疑影響性能,好在瀏覽器給我提供了相應的接口getBoundingClientRect,這個方法最早出現在IE瀏覽器中,后來的瀏覽器也跟著支持了這個方法,而且還更加完善,IE中只能獲取到元素的left,top,bottom,right的屬性,而后面的現代瀏覽器還能獲取到元素的width和height.

    ChromeFirefox (Gecko)Internet ExplorerOperaSafari
    1.03.0 (1.9)4.0(Yes)4.0

    這里要注意的是,bottom是元素底部相對于窗口頂部的距離,而不是像css里面position的bottom相對于窗口底部,同理,rihgt屬性是元素最右邊相對于窗口左邊的距離。

  • var box = document.getElementById("box");
  • var pos = box.getBoundingClientRect();
  • box.innerHTML = "top:"+pos.top +
  • "left:"+pos.left +
  • "bottom:"+pos.bottom +
  • "right:"+pos.right +
  • "width:"+pos.width +
  • "height:"+pos.height
  • 總結

    以上是生活随笔為你收集整理的JS获取元素在页面的位置的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。