offsetWidth/getBoundingRect()/scrollWidth/client用法总结



offsetWidth

offsetWidth是一个只读属性,返回一个元素的布局宽度,为border-box的宽度。

语法:var offsetWidth =element.offsetWidth; 结果为四舍五入的整数
图来源于MDN


getBoundingClientRect()

offsetWidth和其他方式返回的是四舍五入(round)的整数,想要得到小数则要用getBoundingClientRect()方法。

getBoundingClientRect()返回元素的大小及其相对于视口左上角的位置。

包括的属性有:width、height、left、right、top、bottom。


clientWidth

表示元素的内部宽度,以像素计。该属性包括内边距,但不包括垂直滚动条(如果有)、边框和外边距。


scrollWidth

表示元素内容的宽度,包括由于滚动而未显示在屏幕中内容。

宽度的测量方式与clientWidth相同:它包含元素的内边距,但不包括边框,外边距或垂直滚动条(如果存在)。


测试举例


结果:


总结

包含边框(border-box)不包含边框(padding-box)
返回整数offsetWidthclientWidth / scrollWidth
返回小数getBoundingRect().width\
包括滚动部分\scrollWidth
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值