码迷,mamicode.com
首页 > 其他好文 > 详细

scrollWidth,clientWidth与offsetWidth的区别

时间:2014-11-08 13:28:26      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   ar   使用   sp   div   on   log   

scrollWidth 
是对象的实际内容的宽,不包边线宽度,会随对象中内容的多少改变(内容多了可能会改变对象的实际宽度)。
clientWidth 
是对象可见的宽度,不包滚动条等边线,会随窗口的显示大小改变。 
offsetWidth 
是对象的可见宽度,包滚动条等边线,会随窗口的显示大小改变。 

一个scrollWidth和clientWidth的例子: 

<html> 
<head> 
<title>维生素e</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>维生素e</title> 
</head> 
<body> 
<textarea wrap="off" onfocus="alert(‘offsetWidth:‘+this.offsetWidth+‘\n clientWidth:‘+this.clientWidth);"></textarea> 
</body> 
</html>  


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

 

ps:

wrap="virtual" 将实现文本区内的自动换行,以改善对用户的显示,但在传输给服务器时,文本只在用户按下 Enter 键的地方进行换行,其他地方没有换行的效果。

wrap="physical" 将实现文本区内的自动换行,并以这种形式传送给服务器,就像用户真的那样键入的。因为文本要以用户在文本区内看到的效果传输给服务器,因为使用自动换行是非常有用的方法。

如果把 wrap 设置为 off,将得到默认的动作。

scrollWidth,clientWidth与offsetWidth的区别

标签:style   blog   color   ar   使用   sp   div   on   log   

原文地址:http://www.cnblogs.com/vitaminE/p/4082989.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!