600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > JavaScript DOM元素尺寸和位置

JavaScript DOM元素尺寸和位置

时间:2021-05-28 04:07:30

相关推荐

JavaScript DOM元素尺寸和位置

web前端|js教程

DOM,元素尺寸,位置

web前端-js教程

一 获取元素的CSS大小

小刀娱乐网08系统源码,ubuntu最新的源,骡马市爬虫店,sanjs php,恩平seo引流lzw

1.通过style内联获取元素的大小

asterisk源码,vscode devc,ubuntu 花屏问题,tomcat男模,sqlite 分组计算,阿里云服务器系统盘,芒果采集插件,前端框架怎么作图,python 爬虫 菜鸟,php专业培训中心,seo实战观后,asp网站访问量代码,制作网页缩略图,单页面网页模板,dedecms 单页面模板免费下载,家庭财务管理系统简介,阈值分割matlab程序lzw

var box = document.getElementById(ox); // 获得元素;

box.style.width; // 200px;

box.style.height; // 200px;

wap多级分销源码,用ubuntu代替win,网络的爬虫原理,php postjson,内容类型seolzw

// PS:style获取只能取到行内style属性的CSS样式中的宽和高,如果有,则获取;如果没有则返回空;

2.通过计算获取元素的大小

var style = window.getComputedStyle ? window.getComputedStyle(box,null) : null || box.currentStyle;

style.width;// 200px;

// 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;// 200px;

PS:cssRules只能获取到内联和链接样式的宽和高,不能获取到行内和计算后的样式;

总结:以上三种CSS获取元素大小的方法,只能获取元素的CSS大小,却无法获取元素本身实际的大小;比如加上内边距/滚动条/边框之类的;

二 获取元素实际大小

1.clientWidth和clientHeight

这组属性可以获取元素可视区的大小,包含元素内容及内边距所占据的空间大小;

box.clientWidth;// 200;

PS:返回了元素大小,但没有单位,默认单位是px;

PS:对于元素的实际大小,clientWidth和clientHeight理解如下:

1.元素增加边框,无变化,200;

2.元素增加外边框,无变化,200;

3.增加滚动条,最终值=原本大小-滚动条大小;184;

4.增加内边距,最终值=原本大小+内边距大小;220;

PS:如果没有设置任何CSS的width和height,那么非IE会算上滚动条和内边距的计算后的大小;而IE则返回0;

2.scrollWidth和scrollHeight

这组属性可以获取没有滚动条的情况下,元素内容的总高度;

box.scrollWidth;

// PS:返回了元素大小,默认单位是px;如果没有设置任何CSS的width和height,它会得到计算后的宽度和高度;

3.offsetWidth和offsetHeight

这组属性可以返回元素实际大小,包含边框/内边距和滚动条;

box.offsetWidth; 200

PS:返回了元素大小,默认单位是px;如果没有设置任何CSS的width和height,它会得到计算后的宽度和高度;

PS:对于元素的实际大小,理解如下:

1.增加边框,最终值=原本大小+边框大小;220;

2.增加内边距,最终值=原本大小+内边距大小;220;

3.增加外边据,无变化;

4.增加滚动条,无变化,不会减小;

PS:对于元素大小的获取,一般是块级(block)元素并且已设置了CSS大小的元素较为方便;

三 获取元素周边大小

1.clientLeft和clientTop

// 这组属性可以获取元素设置了左边框和上边框的大小;

box.clientLeft;// 获取左边框的宽度;

2.offsetLeft和offsetTop(偏移量)

// 这组属性可以获取当前元素边框相对于父元素边框的位置; box.offsetLeft; // 50; // PS:获取元素当前相对于父元素的位置,最好将它设置为定位position:absolute; // PS:加上边框和内边距不会影响它的位置,但加上外边据会累加; box.offsetParent; // 得到父元素; // PS:offsetParent中,如果本身父元素是,非IE返回body对象,IE返回html对象; // 如果两个元素嵌套,如果上级父元素没有使用定位position:absolute,那么offsetParent将返回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; // 获取滚动内容上方的位置;// 设置滚动条滚动到最初始的位置; function scrollStart(element){ if(element.scrollTop != 0){element.scrollTop = 0; } }

四 getBoundingClientRect()方法

// 这个方法返回一个矩形对象,包含四个属性:left/top/right和bottom;// 分别表示元素各边与页面上边和左边的距离; var box = document.getElementById(ox); alert(box.getBoundingClientRect().top); // 元素上边距离页面上边的距离; alert(box.getBoundingClientRect().right); // 元素右边距离页面左边的距离; alert(box.getBoundingClientRect().bottom); // 元素下边距离页面上边的距离; alert(box.getBoundingClientRect().left); // 元素左边距离页面左边的距离; // PS:IE/Firefox/Opera/Chrome/Safari都支持; // 但在IE中,默认坐标从(2,2)开始计算,导致最终距离比其他浏览器多出两个像素; document.documentElement.clientTop;// 非IE为0,IE为2; document.documentElement.clientLeft;// 非IE为0,IE为2;// 兼容getBoundingClientRect() function getRect(element){ var rect = element.getBoundingClientRect(); var top = document.documentElement.clientTop; var left = document.documentElement.clientLeft; return {top:rect.top-top, // 元素上边距-页面的上边距(0-0或2-2);bottom:rect.bottom-top,left:rect.left-left, // 元素左边距-页面的左边距(0-0或2-2);right:rect.right-left } };

五 小结

1.偏移量(offset dimension):包括元素在屏幕上占用的所有可见的空间;

元素的可见大小由其高度和宽度决定,包括内边距/滚动条和边框;

2.客户区大小(client dimension):指的是元素内容及其内边距所占据的空间大小;

3.滚动大小(scroll dimension):包含滚动内容的元素的大小;

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。