Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说一篇弄懂 clientWidth、clientHeight、clientLeft、clientTop的区别!(3),希望能够帮助你!!!。
1.clientHeight/clientWidth 属性是一个只读属性,它返回该元素的像素高度/宽度,高度/宽度 包含内边距(padding),不包含边框(border),外边距(margin)和滚动条,是一个整数,单位是像素 px。
2.clientTop/clientLeft 属性是一个只读属性,表示一个元素的顶部边框/左边框 的宽度,以像素表示。不包括外边距和内边距。
以下代码均在Chrome浏览器中测试
<!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;
}
.div{
width: 300px;
height: 300px;
padding: 13px;
margin: 17px;
border: 11px teal solid;
background-color: wheat;
}
#btn{
width: 50px;
height: 50px;
}
</style>
</head>
<body>
<div class="div"></div>
<button id="btn">点我</button>
</body>
<script>
let div = document.getElementsByTagName('div')[0]
btn.onclick=function(){
// .div(height/width:300 + padding:13*2) == 326
console.log('clientHeight',div.clientHeight);
console.log('clientWidth',div.clientWidth);
// .div(border:11)
console.log('clientTop',div.clientTop);
console.log('clientLeft',div.clientLeft);
}
</script>
</html>
效果如下:
client(可视区域)相对于offset,scroll来说,比较好理解。
下面将offset、scroll、client的关系以图形的方式来展示:
相关文章:
链接: 一篇弄懂 offsetWidth、offsetHeight、offsetleft、offsetTop和offsetParent的区别!(1).
链接: 一篇弄懂 scrollWidth、scrollHeight、scrollLeft和scrollTop的区别!(2).
今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
上一篇
已是最后文章
下一篇
已是最新文章