博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
offsetWidth/offsetHeight、offsetLeft/offsetTop、offsetParent
阅读量:6247 次
发布时间:2019-06-22

本文共 2776 字,大约阅读时间需要 9 分钟。

接下来我们依然讨论盒模型中的offset系列:offsetWidth/offsetHeight、offsetLeft/offsetTop、offsetParent

clipboard.png

offsetWidth/offsetHeight

正如在上一篇文章,在这里在写一遍,希望把几个类似的词放在一起去理解可以更好的区分他们的意思。

  1. offsetWidth

    就是当前元素的宽度width,包括边框、padding、以及内容的宽度,即:

    offsetWidth === border(left/right) + padding(left/right) + 内容的宽度(width);//或者offsetWidth === clientWidth + border(left/right);
  2. offsetHeight

    就是当前元素的高度height,包括边框、padding、以及内容的高度,即:

    offsetHeight === border(top/bottom) + padding(top/bottom) + 内容的高度(height);//或者offsetHeight === clientHeight + border(top/bottom);

offsetParent

offsetParent:是指父级参照物。父级参照物不是父级元素,父级参照物与父级元素无关。父级参照物默认是body,如果我们给当前元素的父元素设置了position(等于relative|absolute|fixed)在会改变父级参照物。因为一旦我们给父元素设置了position会影响文档流。

例如有这样的文档结构:

//DOM结构
//css .outer{ width: 260px; height: 260px; border: 20px solid red; margin: 20px auto; } .inner{ width: 160px; height: 160px; border: 20px solid green; margin: 20px auto; } .center{ width: 60px; height: 60px; border: 20px solid blue; margin: 20px auto; }

我们可以在控制台这样查看center、inner、outer的父级参照物

center.offsetParent.tagName //=> "BODY"inner.offsetParent.tagName   //=> "BODY"outer.offsetParent.tagName   //=> "BODY"

由此可以说明,如果不给div设置position属性,那么默认的div的父级参照物都是body

下面我们给outer、inner都设置了position:relative会发生什么?

//DOM不发生变化,我们把CSS修改成下面这样.outer{    ***position: relative;***    width: 260px;    height: 260px;    border: 20px solid red;    margin: 20px auto;}.inner{    ***position: relative;***    width: 160px;    height: 160px;    border: 20px solid green;    margin: 20px auto;}.center{    width: 60px;    height: 60px;    border: 20px solid blue;    margin: 20px auto;}

此时我们在控制台查看center、inner、outer的父级参照物

center.offsetParent   //=> div#inner.innerinner.offsetParent    //=> div#outer.outerouter.offsetParent    //=> body

由此可见,给父级设置position可以改变父级参照物。

offsetLeft/offsetTop

offsetLeft/offsetTop:是指当前元素相对于父级参照物的偏移量。

在标准浏览器中是指:当前元素的左边框的外沿到父级参照物边框的内沿,如上图中的4,5,6所示。
在IE8中,offsetLeft是指:当前元素的左边框的外沿到父级参照物的外沿,如上图中的7,8,9所示。

用offsetLeft/offsetTop我们可以计算出当前元素的左上角坐标(即当前元素距离body顶部和body左边的距离)

var offset = function (curEle) {    var topY = curEle.offsetTop,        leftX = curEle.offsetLeft,        parent = curEle.offsetParent;    while (parent.tagName !== 'BODY') {        if (!/MSIE 8/i.test(navigator.userAgent)) {            topY += parent.clientTop;            leftX += parent.clientLeft;        }        topY += parent.offsetTop;        leftX += parent.offsetLeft;        parent = parent.offsetParent;    }    return {X: leftX , Y: topY};}

offsetLeft/offsetTop 和 clientLeft/clientTop的区别

offsetLeft/offsetTop:是指当前元素相对于父级参照物的偏移量。

clientLeft/clientTop:

//clientLeft:盒子左边框的宽度。 clientLeft === paddingLeft; //clientTop:盒子上边框的高度。 clientTop === paddingTop;

转载地址:http://ijlia.baihongyu.com/

你可能感兴趣的文章
python爬虫知识点总结(十八)Scrapy框架基本使用
查看>>
限制textarea的字数(包括复制粘贴)
查看>>
ArcGIS Server中的各种服务
查看>>
HIVE: Transform应用实例
查看>>
Some examples about how to write anonymous method and lambda expression
查看>>
linux下可以禁用的一些服务
查看>>
aria2的下载配置
查看>>
C++扬帆远航——14(求两个数的最大公约数)
查看>>
django-blog-zinna搭建个人blog
查看>>
as3 文本竖排效果实现
查看>>
Window下Eclipse+Tomcat远程调试
查看>>
夜间模式的开启与关闭,父模板的制作
查看>>
2016/4/19
查看>>
计算一元二次方程的根
查看>>
队列和栈
查看>>
升级了U3D引擎一下,苦逼了...
查看>>
Javascript中封装window.open解决不兼容问题
查看>>
100%会用到的angularjs的知识点【新手可mark】
查看>>
Alinq学习日志
查看>>
根据框架的dtd或xsd生成xml文件
查看>>