JS中各种width和height的区别

对于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

猜你喜欢

转载自blog.csdn.net/Daisy_1/article/details/88657009
今日推荐