ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

offsetLeft和offsetTop获取元素偏移

2022-04-13 14:03:34  阅读:208  来源: 互联网

标签:console log father son 偏移 offsetTop offsetLeft margin 200px


 offset概述

offset翻译过来就是偏移量 我们使用offset系列相关属性可以动态的得到该元素的位置(偏移)、大小等

获得元素距离带有定位父元素的位置

获得元素自身的大小(宽度高度)

注意:返回的数值都不带单位

 

  代码示例:

<!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;
        }

        .father {
            width: 200px;
            height: 200px;
            background-color: pink;
            margin: 150px;
        }

        .son {
            width: 100px;
            height: 100px;
            background-color: purple;
            margin: 45px;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>
<script>
    // offset系列
    var father = document.querySelector('.father')
    var son = document.querySelector('.son')
    // 可以得到元素的偏移位置返回的不带单位的数值
    console.log(father.offsetTop);
    console.log(father.offsetLeft);
    // 它以带有定位的父亲为准﹑如果么有父亲或者父亲没有定位则以 body为准
    console.log(son.offsetLeft);
    // 可以得到元素的大小 宽度和高度
</script>

</html>

 offsetWidth和offsetHeight获取元素大小:

代码示例:

<!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;
        }

        .father {
            width: 200px;
            height: 200px;
            background-color: pink;
            margin: 150px;
        }

        .son {
            width: 100px;
            height: 100px;
            background-color: purple;
            margin: 45px;
        }

        .w {
            width: 200px;
            height: 200px;
            background-color: skyblue;
            margin: 0 auto 200px;
        }
    </style>
</head>

<body>
    <div class="father">
        <div class="son"></div>
    </div>
    <div class="w"></div>
</body>
<script>
    // offset系列
    var father = document.querySelector('.father')
    var son = document.querySelector('.son')
    // 可以得到元素的偏移位置返回的不带单位的数值
    console.log(father.offsetTop);
    console.log(father.offsetLeft);
    // 它以带有定位的父亲为准﹑如果么有父亲或者父亲没有定位则以 body为准
    console.log(son.offsetLeft);
    var w = document.querySelector('.w')
    // 可以得到元素的大小 宽度和高度  是包含padding + border + width
    console.log(w.offsetWidth);
    console.log(w.offsetHeight);
    // 返回带有定位的父亲 否则返回的是body
    console.log(son.offsetParent); // 返回带有定位的父亲 否则返回的是body
    console.log(son.parentNode); // 返回father 是最近一级的父亲 不管父亲有无定位
</script>

</html>

 

标签:console,log,father,son,偏移,offsetTop,offsetLeft,margin,200px
来源: https://www.cnblogs.com/lxr0606/p/16139879.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有