offset系列浅析

一 先看定义:

1 offsetParent:HTMLElement.offsetParent 是一个只读属性,返回一个指向最近的(closest,指包含层级上的最近)包含该元素的定位元素。如果没有定位的元素,则 offsetParent 为最近的 table 元素对象或根元素(标准模式下为 html;quirks 模式下为 body)。当元素的 style.display 设置为 “none” 时,offsetParent 返回 null。offsetParent 很有用,因为 offsetTop 和 offsetLeft 都是相对于其内边距边界的
2 offsetLeft:HTMLElement.offsetLeft 是一个只读属性,返回当前元素左上角相对于 HTMLElement.offsetParent 节点的左边界偏移的像素值。
3 offsetWidth offsetHeight 指的是当前元素的边框大小,包括content(height,width)+padding+border

二 看一下代码解释:

    <style>
        *{
            margin:0 ;
            padding: 0 ;
        }
        #bigdv {
            margin-left: 150px;
            margin-top: 50px;
            padding-left: 17px;
            padding-top: 23px;
            width: 300px;
            height: 300px;
            background-color: green;
            border:30px red solid;
            /*position: absolute;*/
        }
        #dv {
            margin-left: 100px;
            margin-top: 100px;
            padding-left: 13px;
            padding-top: 12px;
            width: 100px;
            height: 100px;
            background-color: pink;
            border:10px red solid;
            /*position: absolute;*/
        }
    </style>

    <body>
        <div id="bigdv">
            <div id="dv"></div>
        </div>
    </body>

第一种情况,子级元素和父级元素都没有定位:此时内部的盒子的 offsetLeft值是 297 ;offsetTop 值是 203;offsetWidth 133 ,offsetHeight 132;(也就是包含当前 dv 元素的不是定位元素,那么是 dv 的盒子边界(border边界) 是相对于根元素边界的距离
第二种情况,如果父级元素定位了,子级元素没有定位:此时 内部的盒子的 offsetLeft值是 117 ;offsetTop 值是 123;offsetWidth 133 ,offsetHeight 132;(也就是说,此时盒子是相对于当前元素的父元素(因为父元素定位了,不在相对于根元素)的边界,相对的是父元素盒子的border内边界的距离)
第三种情况,如果父元素定位了,子元素也定位了,并且改变了子元素的定位 left top 值:(如果不设置left和top那么offsetLeft和offsetTop还是117 123)

#dv {
        margin-left: 100px;
        margin-top: 100px;
        padding-left: 13px;
        padding-top: 12px;
        width: 100px;
        height: 100px;
        background-color: pink;
        border:10px red solid;
        position: absolute;
        left: 10px;
        top:10px;
    }

此时 内部的盒子的 offsetLeft值是 110 ;offsetTop 值是 110;offsetWidth 133 ,offsetHeight 132;

第四种情况,父元素没有定位,子元素定位:

#dv {
        margin-left: 100px;
        margin-top: 100px;
        padding-left: 13px;
        padding-top: 12px;
        width: 100px;
        height: 100px;
        background-color: pink;
        border:10px red solid;
        position: absolute;

    }

此时内部的盒子的 offsetLeft值是 297 ;offsetTop 值是 203;offsetWidth 133 ,offsetHeight 132;

如果设置了 子元素定位的 left 和 top

#dv {
        margin-left: 100px;
        margin-top: 100px;
        padding-left: 13px;
        padding-top: 12px;
        width: 100px;
        height: 100px;
        background-color: pink;
        border:10px red solid;
        position: absolute;
        left: 10px;
        top: 10px;
    }

内部的盒子的 offsetLeft值是 110 ;offsetTop 值是 110;offsetWidth 133 ,offsetHeight 132;

三 :其实offset系列问题也不难,主要需要理解两点:

1 子元素的定位基准问题,参考http://blog.csdn.net/qq_35809245/article/details/53637512
2 offsetLeft指的是子元素的边界,相对于父元素的边界,这两个边界到底指哪里
其实归根到底总结为两种情况,
a 如果父级元素没有定位,那么子元素的offsetLeft指的是子元素的 (content +padding+border)的border外边界相对于根元素 body 的边界的距离
b 如果父级元素有定位,那么子元素的 offsetLeft 指的是子元素的(content+padding+border)的border边界距离父元素* border 内边界的距离,如果没有border 则是相对于父元素的padding外边界*的距离。

四 offsetWidth 和 offsetHeight 指的是当前元素的 content+padding+border 的宽度和高度

大家仔细琢磨一下吧。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值