对于JS中各种width和height总是分不太清楚,今天先来仔细分辨一下,记录这些宽度和高度到底有什么秘密吧!
直接上代码:
<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
* {
padding: 0;
margin: 0;
}
#oneDiv {
width: 200px;
height: 900px;
padding: 10px;
margin: 20px;
border: 5px solid lightgreen;
background: yellow;
}
</style>
</head>
<body>
<div id="oneDiv">我是div</div>
</body>
<script type="text/javascript">
console.log("==============浏览器===============")
console.log("clientWidth:", document.body.clientWidth);
console.log("clientHeight:", document.body.clientHeight);
console.log("clientTop:", document.body.clientTop);
console.log("clientLeft:", document.body.clientLeft);
console.log("offsetWidth:", document.body.offsetWidth);
console.log("offsetHeight:", document.body.offsetHeight);
console.log("offsetTop:", document.body.offsetTop);
console.log("offsetLeft:", document.body.offsetLeft);
console.log("scrollWidth:", document.body.scrollWidth);
console.log("scrollHeight:", document.body.scrollHeight);
console.log("scrollTop:", document.body.scrollTop);
console.log("scrollLeft:", document.body.scrollLeft);
console.log("==============div容器===============")
console.log("clientWidth:", document.getElementById('oneDiv').clientWidth);
console.log("clientHeight:", document.getElementById('oneDiv').clientHeight);
console.log("clientTop:", document.getElementById('oneDiv').clientTop);
console.log("clientLeft:", document.getElementById('oneDiv').clientLeft);
console.log("offsetWidth:", document.getElementById('oneDiv').offsetWidth);
console.log("offsetHeight:", document.getElementById('oneDiv').offsetHeight);
console.log("offsetTop:", document.getElementById('oneDiv').offsetTop);
console.log("offsetLeft:", document.getElementById('oneDiv').offsetLeft);
console.log("scrollWidth:", document.getElementById('oneDiv').scrollWidth);
console.log("scrollHeight:", document.getElementById('oneDiv').scrollHeight);
console.log("scrollTop:", document.getElementById('oneDiv').scrollTop);
console.log("scrollLeft:", document.getElementById('oneDiv').scrollLeft);
</script>
</html>
上文代码中,我将每种width和height都打印出来查看实际效果(由于浏览器的不同会导致clientHeight、offsetHeight和scrollHeight三个属性返回的大小有区别,我在此处仅使用谷歌浏览器做示范,在浏览器中这三者返回的都是文档的大小):
现在,我们来具体区别一下:
一、clientWidth和clientHeigh 、 clientTop和clientLeft
1,clientWidth的实际宽度
clientWidth = width+左右padding
2,clientHeigh的实际高度
clientHeigh = height + 上下padding
3,clientTop的实际宽度
clientTop = boder.top(上边框的宽度)
4,clientLeft的实际宽度
clientLeft = boder.left(左边框的宽度)
二、offsetWidth和offsetHight 、 offsetTop和offsetLeft
1,offsetWidth的实际宽度
offsetWidth = width + 左右padding + 左右boder
2,offsetHeith的实际高度
offsetHeith = height + 上下padding + 上下boder
3,offsetTop实际宽度
offsetTop:当前元素 上边框 外边缘 到 最近的已定位父级(offsetParent) 上边框 内边缘的 距离。如果 级都没有定位,则是到body 顶部的距离。
4,offsetLeft实际宽度
offsetLeft:当前元素 左边框 外边缘 到 最近的已定位父级(offsetParent) 左边框 内边缘的距离。如果父级都没有定位,则是到body左边的距离。
三、scrollWidth和scrollHeight 、 scrollTop和scrollLeft
1,scrollWidth实际宽度
scrollWidth:获取指定标签内容层的真实宽度(可视区域宽度+被隐藏区域宽度)。
2,scrollHeight的实际高度
scrollHeight:获取指定标签内容层的真实高度(可视区域高度+被隐藏区域高度)
3,scrollTop
scrollTop :内容层顶部 到 可视区域顶部的距离。
4,scrollLeft
scrollLeft:内容层左端 到 可视区域左端的距离.
原文:https://blog.csdn.net/qq_42089654/article/details/80515916