元素尺寸:offsetWidth offsetHeight ==> 内容+左右padding+左右border
元素偏移量:offsetLeft offsetTop ==> 相对位置到border的距离(包括margin不包括border)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
*{margin: 0; padding: 0;}
#box{
width: 400px;
height: 400px;
background-color: yellowgreen;
margin-left: 10px;
position: relative;
}
#dv{
width: 200px;
height: 200px;
background-color: skyblue;
border: 10px solid pink;
padding: 5px 10px;
margin: 10px auto;
position: absolute;
top: 20px;
left: 20px;
}
</style>
</head>
<body>
<div id="box">
<div id="dv"></div>
</div>
<script>
// 1 获取元素尺寸offsetWidth 内容+左右padding+左右border
var dv = document.querySelector('#dv')
console.log(dv.offsetWidth); // 240
console.log(dv.offsetHeight); // 230
// 2 获取元素偏移量 offsetLeft offsetTop 相对位置到border的距离(包括margin不包括border)
// 若没有开启定位,是相对于页面左上角
console.log(dv.offsetLeft); // 90
console.log(dv.offsetTop); // 10
// 若开启定位,则是相对于父元素定位的偏移量
console.log(dv.offsetLeft); // 20
console.log(dv.offsetTop); // 30
</script>
</body>
</html>