scrollWidth, clientWidth, offsetWidth的区别

转自他的博客:https://www.cnblogs.com/kongxianghai/p/4192032.html

通过一个demo测试这三个属性的差别。

说明:

scrollWidth:对象的实际内容的宽度,不包边线宽度,会随对象中内容超过可视区后而变大。 
clientWidth:对象内容的可视区的宽度,不包滚动条等边线,会随对象显示大小的变化而改变。 
offsetWidth:对象整体的实际宽度,包滚动条等边线,会随对象显示大小的变化而改变。

 

该demo就在页面中放一个textarea元素,采用默认宽高显示。

 

情况1:

元素内无内容或者内容不超过可视区,滚动不出现或不可用的情况下。

scrollWidth=clientWidth,两者皆为内容可视区的宽度。

offsetWidth为元素的实际宽度。

 

情况2:

元素的内容超过可视区,滚动条出现和可用的情况下。

scrollWidth>clientWidth。

scrollWidth为实际内容的宽度。

clientWidth是内容可视区的宽度。

offsetWidth是元素的实际宽度。

 

谢谢白色的海分享!

 

posted @ 2017-12-11 10:06  彭胜光  阅读(15790)  评论(0编辑  收藏  举报