理解scrollWidth,clientWidth与offsetWidth的区别

发布时间:2020-10-08编辑:脚本学堂
本文介绍下,scrollWidth,clientWidth与offsetWidth三者之间的区别,有需要的朋友,可以参考下。

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

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

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

来看具体的例子。

例1,
 

复制代码 代码示例:
<html>
<head>
<title>scrollWidth和clientWidth的例子 - www.jb200.com</title>
</head>
<body>
<textarea wrap="off" onfocus="alert('scrollWidth:'+this.scrollWidth+'n clientWidth:'+this.clientWidth);"></textarea>
</body>
</html>

代码说明:
文本框内输入内容,当横向滚动条没出来前scrollWidth和clientWidth的值是一样的。当一行内容超出文本框的宽度,就有横向滚动条出来了,scrollWidth的值就变了。
可见:
 

scrollWidth 是对象实际内容的宽度。
clientWidth 是对象看到的宽度(不含边线),此例中不会改变。

例2,
 

复制代码 代码示例:
<html>
<head>
<title>clientWidth和offsetWidth的例子 - www.jb200.com</title>
</head>
<body>
<textarea wrap="off" onfocus="alert('offsetWidth:'+this.offsetWidth+'n clientWidth:'+this.clientWidth);"></textarea>
</body>
</html>

代码说明:
 

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

 有兴趣的朋友,亲自动手测试下吧,实际体会下scrollWidth,clientWidth与offsetWidth的区别。