JS操作html元素中的offset
2019-08-01 本文已影响74人
追逐_chase
data:image/s3,"s3://crabby-images/21688/216880c39f6977692f49a86f983bcc4096110213" alt=""
我们在开发中有时会遇到获取元素的width
和height
等样式
<body>
<div id="dv1">
<div id="dv2"></div>
</div>
<input type="button" value="显示效果" id="btn" />
</body>
<script>
var dv1 = document.getElementById("dv1");
//红色div的宽和高
dv1.onclick = function () {
//在style标签中设置的样式属性获取不到
//style属性中设置的样式属性是可以获取到的
//获取元素的样式,下面的方式废了
console.log(this.style.width);
console.log(this.style.height);
};
</script>
data:image/s3,"s3://crabby-images/cba0c/cba0cf6e136d92ae87a123aed1b87208020bd500" alt=""
data:image/s3,"s3://crabby-images/e7794/e7794509e692f83676efbf0095c4f48a553648a3" alt=""
在
style标签
中设置的样式属性获取不到
style属性
中设置的样式属性是可以获取到的
那么如何获取到 width 和height呢? offset属性可以获取
在标准流的情况下
<script>
var dv1 = document.getElementById("dv1");
//红色div的宽和高
my$("btn").onclick = function () {
//以后获取元素的宽和高,应该使用offset系列来获取
/*
*
* offsetWidth:获取元素的宽
* offsetHeight:获取元素的高
* offsetLeft:获取元素距离左边位置的值
* offsetTop:获取元素距离上面位置的值
*
* */
console.log( "宽度:"+dv1.offsetWidth);
console.log( "高度 "+ dv1.offsetHeight);
console.log( "距离左边的距离:"+ dv1.offsetLeft);
console.log("距离顶部的距离:"+ dv1.offsetTop);
/**
*/
};
</script>
data:image/s3,"s3://crabby-images/4cb03/4cb0317a9f34e92e1ce6ac956ce8f682a00feb2a" alt=""
上面例子的布局,只是给父级元素添加了
margin-left padding-left border
data:image/s3,"s3://crabby-images/fdea6/fdea616e3caf6e1371c8c71b5da2740156f7edb2" alt=""
<script>
var dv1 = document.getElementById("dv1");
//红色div的宽和高
my$("btn").onclick = function () {
console.log( "宽度:"+ my$("dv2").offsetWidth);
console.log( "高度 "+ my$("dv2").offsetHeight);
console.log( "距离左边的距离:"+ my$("dv2").offsetLeft);
console.log("距离顶部的距离:"+ my$("dv2").offsetTop);
/**
*/
};
</script>
data:image/s3,"s3://crabby-images/d04a9/d04a974d5ca18c609cd11d05f2737c98546c93e1" alt=""
有次可以得出 在标准流的情况下 子元素的
offsetLeft
= 父元素的margin-left
+padding-left
+border-left
+ 自身元素的margin-left
同理offsetTop
也是如此
定位的情况下
- 不管父级盒子有没有定位,自己元素的
offsetLeft
= 自身的margin-left
+ 自己定位的left
- 如果父级盒子没有定位,那么子元素是相对 祖先元素的
left和margin-left
data:image/s3,"s3://crabby-images/1e8e3/1e8e3e6d94661d9895c7c533b36694f05d0e385e" alt=""
data:image/s3,"s3://crabby-images/48e18/48e18aaad29ab0d61722a234b96589461ccd2fdf" alt=""
- 父级元素定位
data:image/s3,"s3://crabby-images/7c5be/7c5becc1e007c1b4f1e88aa01447f9ea0b3e4cad" alt=""
<script>
var dv1 = document.getElementById("dv1");
//红色div的宽和高
my$("btn").onclick = function () {
console.log( "宽度:"+ my$("dv2").offsetWidth);
console.log( "高度 "+ my$("dv2").offsetHeight);
console.log( "距离左边的距离:"+ my$("dv2").offsetLeft);
console.log("距离顶部的距离:"+ my$("dv2").offsetTop);
};
</script>