获取dom元素的宽度和高度

获取dom元素的宽度和高度
一、获取css的大小

1.第一种通过内联样式

var box = document.getElementById('box');
var w = box.style.width;
var h = box.style.height;

2.通过计算元素的大小(但是在ie情况下有一个问题,那就没写widht和height的css就返回auto);

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

3.通过CSSStyleSheet对象中的cssRules(或rules)属性获取元素大小(但是无法获得计算的样式)

var sheet = document.styleSheets[0];
var rule = (sheet.cssRules || sheet.rules)[0];
var w = rule.style.width;
var h = rule.style.height;

以上三种方法都不行。

二、获取实际的大小

1.clientWidth和clientHeight

var w = box.clientWidth;
var h = box.clientHeight;

说明:padding和scroll变动,才有变化

2.scrollWidth 和box.scrollHeight;

var w = box.scrollWidth;
var h = box.scrollHeight;

说明,1)border变化,不同浏览器有不同变化2)padding变化,有变化3)margin变化,无变化

3.offsetWidth和offsetHeight

var w = box.scrollWidth;
var h = box.scrollHeight;

说明,padding和border有变动,才有变化

三、获取元素周变的距离(原本只能从左边和上边)

1.clientLeft 和 clientTop
这组属性可以获取元素设置了左边框和上边框的大小。

var l = box.clientLeft;
var t = box.clientTop;

2.获取相对父级元素的位置

var l = box.offsetLeft;
var t = box.offsetTop;
var parent = box.offsetParent;  //获取伏击元素,返回body

说明,如果没有position:absolute;如果每个浏览器有不同解释

那么获取多层中的元素到body或html的距离,代码如下:

复制代码
function offsetLeft(element){
var left = element.offsetLeft;
var parent = element.offsetParent;

    while(parent!== null){
        left += parent.offsetLeft;
        parent = parent.offsetParent;
    }
    return left;
}

复制代码
3.

//这组属性可以获取滚动条被隐藏的区域大小,也可设置定位到该区域。
box.scrollTop; //获取滚动内容上方的位置
box.scrollLeft; //获取滚动内容左方的位置

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值