午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    js獲取元素相對窗口位置的實現(xiàn)代碼
    來源:易賢網(wǎng) 閱讀:989 次 日期:2016-06-15 09:44:46
    溫馨提示:易賢網(wǎng)小編為您整理了“js獲取元素相對窗口位置的實現(xiàn)代碼”,方便廣大網(wǎng)友查閱!

    js獲取元素的offsettop,offsetleft等屬性

    obj.clientwidth //獲取元素的寬度

    obj.clientheight //元素的高度

    obj.offsetleft //元素相對于父元素的left

    obj.offsettop //元素相對于父元素的top

    obj.offsetwidth //元素的寬度

    obj.offsetheight //元素的高度

    區(qū)別:

    clientwidth = width + padding

    clientheight = height + padding

    offsetwidth = width + padding + border

    offsetheight = width + padding + border

    offset比client多了border的寬度

    ?123456789101112 //獲取元素的縱坐標(相對于窗口) 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; }

    之前也寫過一篇js關于獲取元素位置的文章:js獲取元素的offsettop,offsetleft等屬性,我們可以通過offsettop和offsetleft屬性獲取元素相對窗口的位置,但offsettop和offsetleft屬性都是相對于父元素定位的,而通常需要獲取位置的元素都不是在最外層,所以遍歷上級元素的offset相關屬性少不了。那效率就成問題了。

    ?123456789101112 //獲取元素的縱坐標(相對于窗口) 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,這個方法最早出現(xiàn)在ie瀏覽器中,后來的瀏覽器也跟著支持了這個方法,而且還更加完善,ie中只能獲取到元素的left,top,bottom,right的屬性,而后面的現(xiàn)代瀏覽器還能獲取到元素的width和

    chrome firefox (gecko) internet explorer opera safari

    1.0 3.0 (1.9) 4.0 (yes) 4.0

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

    ?12345678 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

    更多信息請查看腳本欄目
    易賢網(wǎng)手機網(wǎng)站地址:js獲取元素相對窗口位置的實現(xiàn)代碼

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)