JavaScript offsetParent案例詳解
1. offsetParent定義:那么offsetParent就是距離該子元素最近的進(jìn)行過(guò)定位的父元素(position:absolute relative fixed),如果其父元素中不存在定位則offsetParent為:body元 素
2. 根據(jù)定義分別存在以下幾種情況
- 元素自身有fixed定位,父元素不存在定位,則offsetParent的結(jié)果為null(firefox中為:body,其他瀏覽器返回為null)
- 元素自身無(wú)fixed定位,且父元素也不存在定位,offsetParent為<body>元素
- 元素自身無(wú)fixed定位,且父元素存在定位,offsetParent為離自身最近且經(jīng)過(guò)定位的父元素
- <body>元素的offsetParent是null
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="test1" style="position:fixed"></div> <div id="test2"></div> <div id="div0" style="position:absolute;"> <div id="div1" style="position:absolute;"> <div id='test3'></div> </div> </div> <script> /* 【1】元素自身有fixed定位,父元素不存在定位,則offsetParent的結(jié)果為null(firefox中為:body,其他瀏覽器返回為null) */ var test1 = document.getElementById('test1'); console.log('test1 offsetParent: ' + test1.offsetParent); /* 【2】元素自身無(wú)fixed定位,且父元素也不存在定位,offsetParent為<body>元素 */ var test2 = document.getElementById('test2'); console.log('test2 offsetParent: ' + test2.offsetParent); /* 【3】元素自身無(wú)fixed定位,且父元素也不存在定位,offsetParent為<body>元素 */ var test3 = document.getElementById('test3'); console.log('test3 offsetParent: ' + test3.offsetParent); /* 【4】<body>元素的offsetParent是null */ */ console.log('body offsetParent: ' + document.body.offsetParent);//null </script> </body> </html>
3. IE7中對(duì)于定位的offsetParent,存在以下bug
【1】當(dāng)元素本身經(jīng)過(guò)絕對(duì)定位或相對(duì)定位,且父級(jí)元素?zé)o經(jīng)過(guò)定位的元素時(shí),IE7-瀏覽器下,offsetParent是<html>
<div id="test1" style="position:absolute;"></div> <script> //IE7-瀏覽器返回<html>,其他瀏覽器返回<body> console.log(test1.offsetParent); </script>
<div id="test2" style="position:relative;"></div> <script> //IE7-瀏覽器返回<html>,其他瀏覽器返回<body> console.log(test2.offsetParent); </script>
<div id="test3" style="position:fixed;"></div> <script> //firefox并沒(méi)有考慮固定定位的問(wèn)題,返回<body>,其他瀏覽器都返回null console.log(test3.offsetParent); </script>
【2】如果父級(jí)元素存在觸發(fā)haslayout的元素或經(jīng)過(guò)定位的元素,且offsetParent的結(jié)果為離自身元素最近的經(jīng)過(guò)定位或觸發(fā)haslayout的父級(jí)元素
<div id="div0" style="display:inline-block;"> <div id='test'></div> </div> <script> //IE7-瀏覽器返回<div id="div0">,其他瀏覽器返回<body> console.log(test.offsetParent); </script>
<div id="div0" style="position:absolute;"> <div id="div1" style="display:inline-block;"> <div id='test'></div> </div> </div> <script> //IE7-瀏覽器返回<div id="div1">,其他瀏覽器返回<div id="div0"> console.log(test.offsetParent); </script>
<div id="div0" style="display:inline-block;"> <div id="div1" style="position:absolute;"> <div id='test'></div> </div> </div> <script> //所有瀏覽器都返回<div id="div1"> console.log(test.offsetParent); </script>
到此這篇關(guān)于JavaScript offsetParent案例詳解的文章就介紹到這了,更多相關(guān)JavaScript offsetParent內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript學(xué)習(xí)筆記(十九) 節(jié)點(diǎn)的操作實(shí)現(xiàn)代碼
javascript學(xué)習(xí)筆記之節(jié)點(diǎn)的操作實(shí)現(xiàn)代碼,包括節(jié)點(diǎn)的創(chuàng)建、添加、移除、替換、復(fù)制2012-06-06JavaScript中join()方法的使用簡(jiǎn)介
這篇文章主要介紹了JavaScript中join()方法的使用簡(jiǎn)介,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06ajax上傳時(shí)參數(shù)提交不更新等相關(guān)問(wèn)題
我感覺(jué)好像這個(gè)上傳插件只在第一次點(diǎn)擊的時(shí)候?qū)嵗?shù)傳給后臺(tái),所以以后值都是不變的,應(yīng)該怎么解決這個(gè)問(wèn)題呢2012-12-12原生javascript 學(xué)習(xí)之js變量全面了解
下面小編就為大家?guī)?lái)一篇原生javascript 學(xué)習(xí)之js變量全面了解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07javascript:void(0)的含義及用法實(shí)例
這篇文章介紹了javascript:void(0)的含義及用法實(shí)例,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12