<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>offsetWidth、clientWidth、width、scrollWidth区别及js与jQuery获取的方式</title>
<script type="text/javascript" src="jquery.min.js"></script> </head>
<body style="border:1px solid #ccc">
<div id="div" style="width:100px;height:80px;left:10px;top:8px;position:relative;border:1px solid #ccc;margin:20px 10px;padding:7px 6px;">
</div> <script type="text/javascript">
var divObj = document.getElementById("div"); var dOffsetWidth = divObj.offsetWidth;//返回元素的宽度(包括元素宽度、内边距和边框,不包括外边距)
var $dOffsetWidth = $(divObj).outerWidth(false);//参数为true,包括外边距 var dOffsetHeight = divObj.offsetHeight;//返回元素的高度(包括元素高度、内边距和边框,不包括外边距)
var $dOffsetHeight = $(divObj).outerHeight(false);//参数为true,包括外边距 var dClientWidth = divObj.clientWidth;//返回元素的宽度(包括元素宽度、内边距,不包括边框和外边距)
var $dClientWidth = $(divObj).innerWidth(); var dClientHeight = divObj.clientHeight;//返回元素的高度(包括元素高度、内边距,不包括边框和外边距)
var $dClientHeight = $(divObj).innerHeight(); var dWidth = divObj.style.width;//返回元素的宽度(包括元素宽度,不包括内边距、边框和外边距)
var $dWidth = $(divObj).width();//width(val)设置宽 var dHeight = divObj.style.height;//返回元素的高度(包括元素高度,不包括内边距、边框和外边距)
var $dHeight = $(divObj).height();//height(val)设置高 var dscrollWidth = divObj.scrollWidth;//返回元素的宽度(包括元素宽度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientWidth相同
var dscrollHeight = divObj.scrollHeight;//返回元素的高度(包括元素高度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientHeight相同 console.log("dOffsetWidth:"+dOffsetWidth+",dOffsetHeight:"+dOffsetHeight+",dClientWidth:"+dClientWidth+",dClientHeight:"+dClientHeight+",dWidth:"+dWidth+",dHeight:"+dHeight+",dscrollWidth:"+dscrollWidth+",dscrollHeight:"+dscrollHeight);
console.log("$dOffsetWidth:"+$dOffsetWidth+",$dOffsetHeight:"+$dOffsetHeight+",$dClientWidth:"+$dClientWidth+",$dClientHeight:"+$dClientHeight+",$dWidth:"+$dWidth+",$dHeight:"+$dHeight); /*
注意:offsetWidth(offsetHeight)与style.width(style.height)的区别
1. style.height 返回的是字符串,如28px,offsetWidth返回的是数值28,如果需要对取得的值进行计算,用offsetWidth比较方便;如果拿到offsetWidth设置style.left的值,需加'px'。
2. style.width/style.height与scrollWidth/scrollHeight是可读写的属性,clientWidth/clientHeight与offsetWidth/offsetHeight是只读属性
3. style.height的值需要事先定义,否则取到的值为空。而且必须要定义在html里,如果定义在css里,style.height的值仍然为空,但元素偏移有效;而offsetWidth则仍能取到。
*/ /*
总结:
1、通过style.width(style.height)或者jQuery的$(divObj).width()/$(divObj).height()获取/设置元素的宽高
2、若要获取元素包含边框的宽度,则可通过divObj.offsetWidth/divObj.offsetHeight或jQuery的$(divObj).outerWidth(false)/$(divObj).outerHeight(false)获取
3、通过$(divObj).outerWidth(true)/$(divObj).outerHeight(true)获取带外边距的宽度
4、通过$(divObj).innerWidth()/$(divObj).innerHeight()获取不包含边框、不包含外边距的宽度
*/
</script>
</body>
</html>

技术交流QQ群:15129679

最新文章

  1. 深入理解 &#39;0&#39; &quot;0&quot; &#39;\0&#39; 0 之间的区别
  2. Dynamics AX 2012 R2 报表部署权限错误
  3. System.IO中的File、FileInfo、Directory与DirectoryInfo类(实例讲解)
  4. ios基础篇(八)——UITabBarController的简单介绍
  5. Scala语言初识
  6. Spring连接MySQL、Oracle和SQL Server
  7. Ubuntu12.10 下搭建基于KVM-QEMU的虚拟机环境(三)
  8. 优化php性能的一点总结
  9. hdu2157矩阵快速幂
  10. web开发性能优化---UI界面篇
  11. LeetCode高频148错题记录
  12. Windows驱动开发VS2012 DDK/WDK的环境配置
  13. 《算法》第二章部分程序 part 3
  14. python基础学习 Day19 面向对象的三大特性之多态、封装
  15. Mac下配置Oracle数据库客户端远程连接数据库服务器
  16. javascript函数定义以及常见用法
  17. jquery 浏览器打印
  18. day27 python学习 logging
  19. mvc里全局错误日志
  20. 你可能不知道的 10 条 SQL 技巧,涨知识了!

热门文章

  1. 第二章-如何使用github建立一个HelloWorld项目,git的add/commit/push/pull/fetch/clone等基本命令用法。--答题人:杨宇杰
  2. font-face跨域办法
  3. Powershell-入门
  4. Titanium系列--利用Titanium开发android App实战总结
  5. iOS Swipe Tableviewcell(左右滑动出现按钮)
  6. [ASE][Daily Scrum]11.17
  7. 随机数是骗人的,.Net、Java、C为我作证
  8. 【Leetcode】【Medium】Group Anagrams
  9. 帅呆了!ASP.NET Core每秒能处理115万个请求
  10. 通过git rebase修改commit message