日韩av色在线_av不卡在线观看_亚洲国产精品第一页_在线看日本不卡_色成人综合网_国产丝袜在线视频_国产精成人品localhost_国产91富婆露脸刺激对白_韩国视频一区_国产精品人成电影

當前位置:首頁 > 嵌入式培訓 > 嵌入式學習 > 講師博文 > DOM 元素尺寸與位置

DOM 元素尺寸與位置 時間:2018-09-26      來源:未知

一.獲取元素CSS大小

1.通過style獲取元素的大小

varbox = document.getElementById('box'); //獲取元素

box.style.width;

box.style.height;

PS:style獲取只能獲取到行內style屬性的CSS樣式中的寬和高,如果有,獲取;如果沒有,則返回空。

2.通過計算獲取元素的大小

varstyle = window.getComputedStyle ?

window.getComputedStyle(box,null) : null || box.currentStyle;

style.width; //1424px、200px、auto

style.height; //18px、200px、auto

PS:通過計算獲取元素的大小,無關你是否是行內、內聯或者鏈接,它經過計算后得到的結果返回出來。如果本身設置大小,它會返回元素的大小,如果本身沒有設置,非IE瀏覽器會返回默認的大小,IE瀏覽器返回auto。

3.通過CSSStyleSheet對象中的cssRules(或rules)屬性獲取元素大小

var sheet =document.styleSheets[0]; //獲取link或style

var rule = (sheet.cssRules ||sheet.rules)[0]; //獲取第一條規則

rule.style.width;

rule.style.height;

PS:cssRules(或rules)只能獲取到內聯和鏈接樣式的寬和高,不能獲取到行內和計算后的樣式。

總結:以上的三種CSS獲取元素大小的方法,只能獲取元素的CSS大小,卻無法獲取元素本身實際的大小。比如加上了內邊距(padding)、外邊距(margin)、邊框(border)、滾動條(scroll)之后的大小

二.獲取元素實際大小

測試代碼:

HTML部分:

<body>

<divid="box">

測Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

測試Div測試Div測試Div測試Div測試Div測試Div測試Div測試Div

</div>

</body>

CSS部分:

#box{

width:200px;

height:200px;

background:red;

overflow:scroll;

}

1.clientWidth和clientHeight

這組屬性可以獲取元素可視區的大小,可以得到元素內容及內邊距所占據的空間大小。

box.clientWidth; //200

box.clientHeight; //200

PS:返回了元素大小,但沒有單位,默認單位是px,如果設置了其他的單位,比如100em之類,返回出來的結果還會轉換為px像素。(CSS獲取的話,是照著你設置的樣式獲取)。

PS:對于元素的實際大小,clientWidth和clientHeight理解方式如下:

1.增加邊框,無變化,為200;

2.增加外邊距,無變化,為200;

3.增加滾動條,終值等于原本大小減去滾動條的大小,為184;

4.增加內邊距,終值等于原本大小加上內邊距的大小,為220;

PS:如果說沒有設置任何CSS的寬和高度,那么非IE瀏覽器會算上滾動條和內邊距的計算后的大小,而IE瀏覽器則返回0。

2.scrollWidth和scrollHeight

這組屬性可以獲取滾動內容的元素大小。

box.scrollWidth; //200

box.scrollWidth; //200

PS:返回了元素大小,默認單位是px。如果沒有設置任何CSS的寬和高度,它會得到計算后的寬度和高度。

PS:對于元素的實際大小,scrollWidth和scrollHeight理解如下

1.增加邊框,不同瀏覽器有不同解釋:

a) Firefox和Opera瀏覽器會增加邊框的大小,220 x 220

b) Chrome和Safari瀏覽器會忽略邊框大小,200 x 200

c) IE瀏覽器忽略邊框并且只顯示它有效內容的高度,200 x 18(單個“測試 Div”的高度為18)

2.增加內邊距,終值會等于原本大小加上內邊距大小,220 x 220,IE為220x 38

3.增加滾動條,終值會等于原本大小減去滾動條大小,184 x 184,IE為184x 18

4.增加外邊據,無變化。

5.增加內容溢出(若果沒有滾動條,不同瀏覽器兼容不同,所以加上滾動條overflow:scroll;),Firefox、Chrome和IE獲取實際內容高度,Opera比前三個瀏覽器獲取的高度偏小,Safari比前三個瀏覽器獲取的高度偏大。

3.offsetWidth和offsetHeight(穩定,使用頻率高!)

這組屬性可以返回元素實際大小,包含邊框、內邊距和滾動條。

box.offsetWidth; //200

box.offsetHeight; //200

PS:返回了元素大小,默認單位是px。如果沒有設置任何CSS的寬和高度,他會得到計算后的寬度和高度。

PS:對于元素的實際大小,offsetWidth和offsetHeight理解如下:

1.增加邊框,終值會等于原本大小加上邊框大小,為220;

2.增加內邊距,終值會等于原本大小加上內邊距大小,為220;

3.增加外邊據,無變化;

4.增加滾動條,無變化,不會減小;

HTML部分:

<body>

<divid="box">

測試Div

</div>

</body>

CSS部分:

#box{

width:200px;

height:200px;

background:red;

}

PS:對于元素大小的獲取,一般是塊級(block)元素并且以設置了CSS大小的元素較為方便。如果是內聯元素(inline)或者是沒有設置大小的元素就尤為麻煩,所以,建議使用的時候注意。

三.獲取元素周邊大小

1.clientLeft和clientTop

這組屬性可以獲取元素設置了左邊框和上邊框的大小。

box.clientLeft; //獲取左邊框的長度

box.clientTop; //獲取上邊框的長度

PS:目前只提供了Left和Top這組,并沒有提供Right和Bottom。如果四條邊寬度不同的話,可以直接通過計算后的樣式獲取,或者采用以上三組獲取元素大小的減法求得。

2.offsetLeft和offsetTop

這組屬性可以獲取當前元素相對于父元素的位置。

box.offsetLeft;

box.offsetTop;

PS:獲取元素當前相對于父元素的位置,好將此元素設置為絕對定位position:absolute;否則不同的瀏覽器會有不同的解釋。

PS:加上邊框和內邊距不會影響它的位置,但加上外邊距會累加。

box.offsetParent; //得到父元素

PS:offsetParent中,如果本身父元素是,非IE返回body對象,IE返回html對象。如果兩個元素嵌套,如果父元素沒有使用定位position:absolute,那么offsetParent將返回body對象或html對象。所以,在獲取offsetLeft和offsetTop時候,CSS定位很重要。

如果說,在很多層次里,外層已經定位,我們怎么獲取里層的元素距離body或html元素之間的距離呢?也就是獲取任意一個元素距離頁面上的位置。那么我們可以編寫函數,通過不停的向上回溯獲取累加來實現。代碼如下:

//只有兩層的情況下:

box.offsetTop+ box.offsetParent.offsetTop;

//如果多層的話,就必須使用循環或遞歸:

function offsetLeft(element) {

var left = element.offsetLeft; //得到第一層距離

var parent = element.offsetParent; //得到第一個父元素

while (parent !== null) { //如果還有上一層父元素

left += parent.offsetLeft; //把本層的距離累加

parent = parent.offsetParent; //得到本層的父元素

} //然后繼續循環

return left;

}

3.scrollTop和scrollLeft

這組屬性可以獲取滾動條被隱藏的區域大小,也可設置定位到該區域。

box.scrollTop; //獲取滾動內容上方的位置(就是隱藏的內容的高度)

box.scrollLeft; //獲取滾動內容左方的位置

如果要讓滾動條滾動到初始的位置,那么可以寫一個函數:

functionscrollStart(element) {

if (element.scrollTop != 0) element.scrollTop = 0; //賦值為0;

}

上一篇:理解js中this的指向問題

下一篇:Android動畫

熱點文章推薦
華清學員就業榜單
高薪學員經驗分享
熱點新聞推薦
前臺專線:010-82525158 企業培訓洽談專線:010-82525379 院校合作洽談專線:010-82525379 Copyright © 2004-2022 北京華清遠見科技集團有限公司 版權所有 ,京ICP備16055225號-5京公海網安備11010802025203號

回到頂部

中文字幕在线观看1| 羞羞视频在线免费国产| 日本视频在线观看免费| 日韩精品你懂的| 999国产在线| 亚洲第一页在线| 亚洲欧美国产三级| 另类的小说在线视频另类成人小视频在线 | 成人一区二区三区仙踪林| 欧美日韩大片一区二区三区| 欧美—级a级欧美特级ar全黄| 在线观看一区不卡| 国产精品国产三级国产a| 久久一区国产| 四季av一区二区凹凸精品| 久久亚洲人体| 污污网站在线看| 久草在线资源视频| 你懂的免费视频| 亚洲av成人精品一区二区三区在线播放 | 国产原创精品| 人九九综合九九宗合| 在线视频中文亚洲| 91精品国产aⅴ一区二区| 亚洲美女偷拍久久| 91婷婷韩国欧美一区二区| 天堂成人免费av电影一区| 91亚洲国产高清| 国产精品调教| 国产韩日精品| 亚洲电影观看| gogo在线高清视频| 国产天堂在线| 中文字幕视频免费在线观看| www.天天操.com| 一个人看的www视频免费观看| 欧美视频一二区| 中文字幕人妻精品一区| 粉嫩aⅴ一区二区三区| 国产午夜手机精彩视频| 全黄一级裸体片| 国产麻豆剧传媒精品国产| 免费男同深夜夜行网站| 国产a级片网站| 欧美aⅴ99久久黑人专区| 免费福利在线观看| 男人免费av| 免费男女羞羞的视频网站中文版| 99t1这里只有精品| 久久久久亚洲精品一区二区三区| 午夜视频在线播放| 亚洲高清视频在线播放| 国产精品高潮呻吟AV无码| 欧美一级淫片免费视频黄| 麻豆一区二区三区精品视频| 三级av在线免费观看| 亚洲第一综合网| 伊人网伊人影院| 波多野结衣av在线免费观看| 免费的av网站| aaaaa一级片| 色一情一交一乱一区二区三区 | 亚洲欧美日本日韩| 亚洲欧洲日本mm| 黄色精品免费| 一本综合久久| 香蕉国产精品偷在线观看不卡| 91久久夜色精品国产九色| 亚洲青色在线| 性色一区二区三区| 天堂蜜桃91精品| 精品亚洲porn| 成人午夜av影视| 26uuu久久综合| 国产精品麻豆一区二区| 亚洲天堂2014| 精品国产福利在线| 日本精品视频一区二区| 欧美日韩美少妇 | 8x8ⅹ国产精品一区二区二区| 在线电影看在线一区二区三区| 亚洲日本无吗高清不卡| 300部国产真实乱| 欧美在线一区视频| 亚洲高清在线免费观看| 手机在线视频一区| 国产精品无码永久免费不卡| 日本综合在线观看| 美女的奶胸大爽爽大片| 好看的av在线| 国产成人精品一区二三区四区五区| 亚洲免费成人网| 欧美另类交视频| 成年人免费影院| julia中文字幕久久亚洲蜜臀 | 亚洲一区国产| 狠狠色综合播放一区二区| av在线不卡电影| 岛国在线视频| 丁香久久五月| 性生活视频网站| 国产a国产a国产a| 你懂的在线免费观看| 午夜激情在线| www.久久久.com| 欧美一区二区三区激情视频| 亚洲性图久久| 国产美女精品在线| 国产精品日韩精品欧美在线| 天天亚洲美女在线视频| 日韩午夜激情电影| 中文字幕亚洲一区在线观看 | 欧美一区二区三区四区高清| 国产亚洲激情在线| 欧美亚洲伦理www| 国产一区免费| www.爱色av.com| 中文字幕第3页| 在线观看成人毛片| 国产人妖一区二区三区| 在线播放黄色网址| 最新国产在线| 99久久精品免费看国产小宝寻花 | 免费福利在线观看| 波多视频一区| 国内精品久久久久久久影视简单| 老牛国产精品一区的观看方式| 26uuu亚洲| 欧美性欧美巨大黑白大战| 国产亚洲精品一区二555| 国产精品久久久久99| 天天综合色天天综合色hd| 国产一线二线三线在线观看| 69xxx免费| 亚洲欧美高清视频| 啊啊啊啊啊好爽| 爱情岛亚洲播放路线| 蜜桃国内精品久久久久软件9| 午夜在线精品| 国产精品麻豆99久久久久久| 日韩视频在线你懂得| 98精品在线视频| 你懂的视频在线一区二区| 日韩欧美国产片| www.国产com| 三级福利视频| 日本高清成人vr专区| 国产在视频线精品视频www666| 精一区二区三区| 色婷婷精品久久二区二区蜜臀av| 久久久久北条麻妃免费看| 欧美精品在线一区| 国产日韩视频一区| 91丨porny丨在线中文| 夜夜操 天天操| 亚洲v.com| 亚洲精品孕妇| 亚洲制服丝袜av| 视频在线一区二区| 欧美日韩免费精品| 91视频啊啊啊| 人妻少妇精品无码专区| 在线观看理论片| 亚州一区二区| 久久99国产精品久久99| 色偷偷久久一区二区三区| 久久久久久免费精品| 天天在线免费视频| 中文字幕电影av| 国产精品jvid在线观看| 国产美女一区视频| 亚洲国产专区| 香蕉久久一区二区不卡无毒影院| 久久精品2019中文字幕| 一区二区三区四区在线视频| 日本欧美一区二区三区不卡视频| 亚洲视频网站在线| 久久久久久国产精品免费无遮挡 | 黄视频在线免费看| 先锋资源久久| 亚洲欧美视频在线观看| 久久综合亚洲社区| 97碰在线视频| 69成人免费视频| caoporn超碰国产公开| 国产95亚洲| 成人亚洲精品久久久久软件| 精品久久久三级丝袜| 国产激情美女久久久久久吹潮| 国产老头和老头xxxx×| www.亚洲欧美| 91精彩视频在线观看| 91精品蜜臀一区二区三区在线| 亚洲免费视频中文字幕| 国产做受高潮69| 欧美 国产 日本| 中文字幕人妻互换av久久| 丝袜视频国产在线播放| 99国产精品一区二区| 亚洲午夜免费视频| 国产aaa精品| 深夜做爰性大片蜜桃| 午夜视频福利在线| 97超碰免费在线| 毛片av中文字幕一区二区| 精品国产一区二区三区不卡 | 日韩欧美视频| 夜夜嗨av一区二区三区四季av| 欧美黑人性猛交| 成人小视频在线看| 国产xxxxxx| av在线免费网址| 麻豆精品网站| 精品国产一区二区三区忘忧草| 欧洲av一区| 国产在线免费视频| 网址你懂得在线观看| 欧美国产一级| 在线精品视频一区二区| 好吊色欧美一区二区三区| 精品无码一区二区三区蜜臀| 日本成人a视频| 欧美日韩播放| 欧美性xxxx极品hd欧美风情| 懂色av一区二区三区在线播放| 在线小视频你懂的| jizz亚洲大全| 97精品一区二区| 欧美日韩激情在线| 色噜噜一区二区| 中国老头性行为xxxx| 在线h片观看| 国产精品亚洲专一区二区三区 | 波多野结衣作品集| 久久一区二区免费播放| 欧美电影h版| 久久精品人人做人人爽人人| 久久久久国产视频| 涩视频在线观看| 丁香激情五月婷婷| 首页国产精品| 日韩三级视频在线看| 欧美激情亚洲天堂| 亚洲欧洲国产综合| 欧一区二区三区| 午夜影院在线观看欧美| 欧美日韩电影一区二区三区| 欧美一级黄视频| 高潮在线视频| 国产女人18水真多18精品一级做 | а天堂中文在线资源| 黄页网址大全在线观看| 国产欧美日韩一区二区三区在线| 亚洲第一天堂av| 手机视频在线观看| 日日摸.com| 婷婷另类小说| 日韩电影大片中文字幕| 免费看涩涩视频| 比比资源-先锋影音资源站| 无码一区二区三区视频| 亚洲精品理论电影| 中文字幕免费高清在线| 找av导航入口| 亚洲每日更新| 久久综合久中文字幕青草 | www.久草.com| 国产精品综合| 久久91精品国产| 在线免费看视频| 午夜免费视频在线国产| 91在线看国产| 91免费观看| 91久久精品国产91性色69| 香蕉久久免费电影| 亚洲成人综合在线| gogogo免费高清日本写真| 原谅我中文字幕| 久久久综合色| 视频在线观看一区二区| 一区二区三区在线观看免费视频| 国产尤物视频在线| 99久久精品免费| 国产精品国色综合久久| 99热这里只有精品66| 日韩欧美中文在线观看| 欧美日韩久久一区二区| 日本 片 成人 在线| 精品伦理一区二区| 国产成人午夜精品影院观看视频 | 国产一级二级三级| 国产在线88av| 五月天网站亚洲| 欧美黑人经典片免费观看| 黄色三级视屏| 秋霞av亚洲一区二区三| 国产精品扒开腿做爽爽爽的视频| 日韩美女视频网站| 日韩成人精品一区二区三区| 精品视频一区 二区 三区| 免费看涩涩视频| 伊人网在线观看| 久久久久久久久久美女| 亚洲精品无人区| 91嫩草香蕉| 全国精品久久少妇| 91亚洲国产精品| 成人久久久精品国产乱码一区二区| 免费看成人哺乳视频网站| 中文亚洲视频在线| av激情在线观看| 狠狠综合久久av一区二区小说| 久草在线官网| 成年人免费视频播放| 乳奴隷乳フ辱| 日日夜夜精品视频天天综合网| 97超级碰碰人国产在线观看| 日产精品久久久久| 欧美国产日本在线| 99久热在线精品996热是什么| 本网站久久精品| 3d动漫精品啪啪| 国产十八熟妇av成人一区| 99reav在线| 亚洲综合激情另类小说区| 成年人网站免费视频| 国产对白在线| 99久久精品99国产精品 | 免费看黄色三级| 欧亚av在线| 69堂精品视频| 熟女俱乐部一区二区| 免费男女羞羞的视频网站在线观看| 欧美午夜精品久久久久久浪潮| 91欧美视频在线| 日本高清视频在线观看| 欧美性猛交丰臀xxxxx网站| 久久精品视频在线观看免费| 国产精品剧情| 欧美精品久久一区二区三区| 亚洲国产精品成人综合久久久| av剧情在线观看| 欧美一级高清片| www.黄色com| 亚洲精品18| 欧美成人激情在线| 国产免费久久久| 欧美三区美女| 岛国一区二区三区高清视频| 小视频在线播放| 99国产精品国产精品久久| 成人污网站在线观看| 中文字幕在线免费播放| 亚洲高清不卡在线| 国产高潮失禁喷水爽到抽搐| 午夜不卡影院| 亚洲欧美精品一区| 国产美女www| 你懂的成人av| 国产日韩亚洲精品| 天天色天天干天天| 亚洲欧洲制服丝袜| 苍井空张开腿实干12次| 欧美电影网站| 久久香蕉国产线看观看av| 精品人妻一区二区三区蜜桃| 久久久久.com| 中文字幕一区二区三区有限公司| 色佬视频在线观看| 91成人免费电影| 日韩一区二区三区四区在线| 精品国产123区| 亚洲在线免费看| 免费成人黄色网址| 精品欧美一区二区三区| 亚洲精品成人av久久| 午夜精品影视国产一区在线麻豆| 国产精品∨欧美精品v日韩精品| 久久99国产精品久久99小说| 99国产精品国产精品久久| 天天操天天干天天做| 电影亚洲一区| 久久久久久久久久久91| 亚洲精品aaaa| 久久久精品黄色| xxxxwww一片| 66精品视频在线观看| 国产精品狼人色视频一区| 九色蝌蚪自拍| 亚洲成人综合在线| 91香蕉一区二区三区在线观看| 国产探花一区在线观看| 国内精品国语自产拍在线观看| 性网站在线免费观看| 在线欧美日韩精品| 羞羞影院体验区| 久久这里有精品15一区二区三区| 毛片在线视频观看| free性欧美16hd| 久久久久久午夜|