JS中关于clientWidth offsetWidth scrollWidth 等的含义

本文详细介绍了网页中各种尺寸和位置属性的功能及使用方法,包括网页可见区域、正文宽高、滚动距离等属性的区别与联系,适用于前端开发人员学习与参考。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网页可见区域宽:

document.body.clientWidth;

网页可见区域高:

 document.body.clientHeight;

网页可见区域宽:

 document.body.offsetWidth(包括边线的宽);

网页可见区域高:

document.body.offsetHeight(包括边线的宽);

网页正文全文宽:

 document.body.scrollWidth;

网页正文全文高:

 document.body.scrollHeight;

网页被卷去的高:

 document.body.scrollTop;

网页被卷去的左:

 document.body.scrollLeft;

网页正文部分上:

 window.screenTop;

网页正文部分左:

 window.screenLeft;

屏幕分辨率的高:

 window.screen.height;

屏幕分辨率的宽:

 window.screen.width;

屏幕可用工作区高度:

window.screen.availHeight;

屏幕可用工作区宽度:

window.screen.availWidth;

1、offsetWidth:width+padding+border)

当前对象的宽度。

style.width也是当前对象的宽度(width+padding+border)。

区别:

  • style.width返回值除了数字外还带有单位px;
  • 如对象的宽度设定值为百分比宽度,则无论页面变大还是变小,style.width都返回此百分比,而offsetWidth则返回在不同页面中对象的宽度值而不是百分比值;
  • 如果没有给 HTML 元素指定过 width样式,则 style.width 返回的是空字符串;

2、offsetHeight :(Height+padding+border)

当前对象的高度。
style.height也是当前对象的高度(height+padding+border)。

区别:

  • style.height返回值除了数字外还带有单位px;
  • 如对象的高度设定值为百分比高度,则无论页面变高还是变矮,style.height都返回此百分比,而offsetHeight则返回在不同页面中对象的高度值而不是百分比值;
  • 如果没有给 HTML 元素指定过 height样式,则 style.height返回的是空字符串;

3、offsetLeft :
当前对象到其上级层左边的距离。
不能对其进行赋值.设置对象到其上级层左边的距离请用style.left属性。
style.left当前对象到其上级层左边的距离。

区别:

  • style.left返回值除了数字外还带有单位px;
  • 如对象到其上级层左边的距离设定值为百分比,style.left返回此百分比,而offsetLeft则返回到其上级层左边的距离的值;
  • 如果没有给 HTML 元素指定过 left样式,则 style.left返回的是空字符串;

4、offsetTop :
当前对象到其上级层顶部边的距离。
不能对其进行赋值.设置对象到上级层顶部边的距离请用style.top属性。
style.top当前对象到其上级层顶部边的距离。

区别:

  • style.top返回值除了数字外还带有单位px;
  • 如对象到其上级层顶部边的距离设定值为百分比, style.top返回此百分比,而offsetTop则返回到其上级顶部边的距离的值;
  • 如果没有给 HTML 元素指定过 top样式,则 style.top返回的是空字符串;

注意:如果上级层为body,由于IE、FF对padding、margin的解释不一样所以要明确规定处理不是下列的区别就不成立了。

IE

  • 如果Div的上级层是body,而div与body之间有个div,如body->div->divo;divo的offsetTop=div的padding+margin+boder;
  • 如果Div的上级层是body,如body>divo;divo的offsetTop=div的padding+margin+boder;

这divo的offsetTop=divo的margin >body.padding则为divo的margin,否则为body.padding谁大是谁?

FF 上述两种情况:offsetTop=margin+padding ;

(IE与FF中的body默认padding为10)在IE6.0 FF3.6.13

5、scrollWidth:获取对象的滚动宽度 。

6、scrollHeight: 获取对象的滚动高度。

7、scrollLeft:设置或获取位于对象左边界和对象中目前可见内容的最左端之间的距离(width+padding为一体)

8、scrollTop:设置或获取位于对象最顶端和对象中可见内容的最顶端之间的距离;(height+padding为一体)

9、clientWidth: 获取对象可见内容的宽度,不包括滚动条,不包括边框;

10、clientHeight: 获取对象可见内容的高度,不包括滚动条,不包括边框;

11、clientLeft: 获取对象的border宽度

12、clientTop:获取对象的border高度

13、offsetParent :当前对象的上级层对象.

IE6.0、FF1.06+:
clientWidth = width + padding
clientHeight = height + padding
offsetWidth = width + padding + border
offsetHeight = height + padding + border

IE5.0/5.5:
clientWidth = width - border
clientHeight = height - border
offsetWidth = width
offsetHeight = height

以上属性测试的文档类型为:

如果不写文档类型,浏览器就会按照 HTML 4.0 的方式来处理,则效果可能不同。
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值