DOM盒模型的各種width和height屬性

client系列(和內(nèi)容是否溢出盒子無關(guān))

  1. clientWidth:內(nèi)容的寬度+左右padding
  2. clientHeight:內(nèi)容的高度+上下padding
  3. clientLeft:左邊框的寬度(border-left-width)
  4. clientTop:上邊框的寬度(border-top-width)

offset系列(和內(nèi)容是否溢出盒子無關(guān))

  1. offsetWidth:clientWidth+左右邊框
  2. offsetHeight:clientHeight+上下邊框
  3. offsetLeft:子元素的外邊框相對于父定位元素(沒有則指向body)的內(nèi)邊框的偏移量
  4. offsetTop:子元素的外邊框相對于父定位元素(沒有則指向body)的內(nèi)邊框的偏移量
  5. offsetParent: 指向子元素的定位父元素逛裤,如果沒有就指向body脯丝,body指向null碌识。

scroll系列

  1. scrollWidth:當(dāng)內(nèi)容未溢出容器時等于clientWidth.當(dāng)溢出時是真實(shí)寬度+左右padding
  2. scrollHeight:當(dāng)內(nèi)容未溢出容器時等于clientHeight檐涝。當(dāng)溢出時是真實(shí)高度+上下padding
  3. scrollTop:滾動條卷去的高度
  4. scrollLeft:滾動條卷去的寬度
    注:如果設(shè)置了overflow:hidden;各瀏覽器結(jié)果不同捣卤。

取值問題

我們通過這13個屬性獲取的都是近似的整數(shù)祠挫。

瀏覽器的盒模型

  1. 對于瀏覽器而言西饵,clientWidth/clientHeight是當(dāng)前瀏覽器可視窗口的寬高(一屏幕的寬高)
  2. 對于瀏覽器而言,scrollWidth/scrollHeight是當(dāng)前頁面的真實(shí)寬高(所有屏加起來寬高的近似值)

瀏覽器盒模型屬性獲取/設(shè)置方法的封裝

function win (attr,value) {
    if (typeof value !=='undefined') {
        return document.documentElement[attr] ||document.body[attr];
    }
    document.documentElement[attr]=value;
    document.body[attr]=value;
}

獲取某元素相對瀏覽器的偏移量 方法的封裝

function offset (curEle) {
    var l=curEle.offsetLeft;
    var t=curEle.offsetTop;
    var par=curEle.offsetParent;
    //一層層定位祖先向上累加
    while (par) {
        if (window.navigator.userAgent.indexOf('MSIE 8.0')!==-1) {
                l+=par.clientLeft;
                t+=par.clientTop;
        }
        l+=par.offsetLeft;
        t+=par.offsetTop;
        par=par.offsetParent;
    }
    return {left:l,top:t};
}

計算后的樣式值的獲取

一般我們用 元素.style.樣式來獲取元素的樣式犀变。這樣獲取到的是元素的行內(nèi)樣式妹孙。如果想獲取元素經(jīng)過計算后的樣式需要使用window.getComputedStyle(ele,null);
經(jīng)過瀏覽器計算過的樣式是指 只要當(dāng)前標(biāo)簽可以在瀏覽器中呈現(xiàn)出來,那么他所有樣式都是經(jīng)過瀏覽器計算過的获枝,哪怕那些樣式你沒有寫也可以獲取到蠢正。
window.getComputedStyle(box,null)接收兩個參數(shù)。 box指要獲取樣式的元素省店,null指偽類嚣崭。

獲取計算后樣式的 方法封裝

function getCss (curEle,attr) {
    var val=null;
    try {
        val=window.getComputedStyle(curEle,null)[attr];
    } catch (e) {
        val=curEle.currentStyle[attr];
    }
    return val;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市懦傍,隨后出現(xiàn)的幾起案子雹舀,更是在濱河造成了極大的恐慌,老刑警劉巖粗俱,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件说榆,死亡現(xiàn)場離奇詭異,居然都是意外死亡寸认,警方通過查閱死者的電腦和手機(jī)签财,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來偏塞,“玉大人唱蒸,你說我怎么就攤上這事【牡穑” “怎么了神汹?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長古今。 經(jīng)常有香客問我屁魏,道長,這世上最難降的妖魔是什么捉腥? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任蚁堤,我火速辦了婚禮,結(jié)果婚禮上但狭,老公的妹妹穿的比我還像新娘披诗。我一直安慰自己,他們只是感情好立磁,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布呈队。 她就那樣靜靜地躺著,像睡著了一般唱歧。 火紅的嫁衣襯著肌膚如雪宪摧。 梳的紋絲不亂的頭發(fā)上粒竖,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天,我揣著相機(jī)與錄音几于,去河邊找鬼蕊苗。 笑死,一個胖子當(dāng)著我的面吹牛沿彭,可吹牛的內(nèi)容都是我干的朽砰。 我是一名探鬼主播,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼喉刘,長吁一口氣:“原來是場噩夢啊……” “哼瞧柔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起睦裳,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤造锅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后廉邑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哥蔚,經(jīng)...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年蛛蒙,在試婚紗的時候發(fā)現(xiàn)自己被綠了糙箍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡宇驾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出猴伶,到底是詐尸還是另有隱情课舍,我是刑警寧澤,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布他挎,位于F島的核電站筝尾,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏办桨。R本人自食惡果不足惜筹淫,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望呢撞。 院中可真熱鬧损姜,春花似錦、人聲如沸殊霞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽绷蹲。三九已至棒卷,卻和暖如春顾孽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背比规。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工若厚, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蜒什。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓测秸,卻偏偏與公主長得像,于是被迫代替她去往敵國和親吃谣。 傳聞我的和親對象是個殘疾皇子乞封,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,587評論 2 350

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,737評論 1 92
  • HTML標(biāo)簽解釋大全 一岗憋、HTML標(biāo)記 標(biāo)簽:!DOCTYPE 說明:指定了 HTML 文檔遵循的文檔類型定義(D...
    米塔塔閱讀 3,229評論 1 41
  • Window和document對象的區(qū)別 window對象window對象表示瀏覽器中打開的窗口window對象是...
    FConfidence閱讀 2,164評論 0 5
  • 簡介網(wǎng)絡(luò)瀏覽器很可能是使用最廣的軟件肃晚。在這篇入門文章中,我將會介紹它們的幕后工作原理仔戈。我們會了解到关串,從您在地址欄輸...
    wengjq閱讀 2,013評論 2 15
  • 清涼法語#學(xué)會智慧的聽話 一個再好的人也有缺點(diǎn),如果有人別有用心监徘,將他的缺點(diǎn)無限擴(kuò)大晋修,很有可能被當(dāng)做壞人;相反一個...
    xcy無名閱讀 127評論 0 0