scrollWidth,clientWidth与offsetWidth的区别

本文详细解释了网页元素的scrollWidth、clientWidth与offsetWidth的区别。scrollWidth反映的是元素实际内容的宽度;clientWidth表示可见区域的宽度,不包括边线;而offsetWidth则包括了边线在内的总宽度。

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

js各种宽度高度值

 


(注意:CSS中的margin属性,与clientWidth、offsetWidth、clientHeight、offsetHeight均无关)

scrollWidth
对象的实际内容的宽不包边线宽度,会随对象中内容的多少改变(内容多了可能会改变对象的实际度)


clientWidth
对象可见的宽度不包滚动条等边线,会随窗口的显示大小改变。


offsetWidth
对象的可见宽度包滚动条等边线,会随窗口的显示大小改变。
一个scrollWidth和clientWidth的例子:


<html>
<head>
<title>ctt.htm文件</title>
</head>
<body>
<textarea wrap="off" onfocus="alert('scrollWidth:'+this.scrollWidth+'/n clientWidth:'+this.clientWidth);"></textarea>
</body>
</html>


在文本框内输入内容,当横向滚动条没出来前scrollWidth和clientWidth的值是一样的。当一行内容超出文本框的宽度,就有横向滚动条出来了,scrollWidth的值就变了。
scrollWidth是对象实际内容的宽度。
clientWidth是对象看到的宽度(不含边线)。
一个clientWidth和offsetWidth的例子:


<html>
<head>
<title>77.htm文件</title>
</head>
<body>
<textarea wrap="off" onfocus="alert('offsetWidth:'+this.offsetWidth+'/n clientWidth:'+this.clientWidth);"></textarea>
</body>
</html>


offsetWidth的值总是比clientWidth的值大。
clientWidth是对象看到的宽度(不含边线)
offsetWidth是对象看到的宽度(含边线,如滚动条的占用的宽)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值