如何根据父级元素进行相对定位

需求:首先有个父级div,若干子元素如何根据父元素的位置进行相对定位?

分析:看到这个需求,我首先想到的是position:relative;然而并不能满足需求。大家可以亲手试试,为啥不能满足呢?因为position:relative是指元素相对于在文档流中位置进行移动的,而不是以父元素为基准进行移动的。

那如何解决?
方法是:将父元素的position设为relative,将子元素的定位方法设为absolute。
解释:当元素的position设为absolute时,如果父级元素没有设置position属性,则元素的基准点就为浏览器的左上角,而当父元素设置了position属性时,那么元素将以父元素为基准点。

注意当父元素设置为了relative之后,子元素相对定位时将会顾及到padding的值。本质上,padding的设定实际上是将元素的边界外延。因此,如果父元素设定了padding之后,子元素相对父元素进行定位时很容易跑偏。如何解决呢?

我们看到父元素既然已经设定了relative,relative就是相对于原来位置进行移动的,那自然可以使用left和top等属性来调整父元素的位置,但是父元素的边界并没有变化。

代码如下:

<!doctype>
<html>
<head>
    <title>测试父元素和子元素的相对定位</title>
    <meta http-equiv="content-type" content="text/html;charset=utf8">
    <style type="text/css">
        #main{
            width: 500px;
            height: 500px;
            position: relative;
            margin: auto;
        }
        .child{
            width: 50px;
            height: 50px;
            position: absolute;
        }
        #one{
            background-color: red;
            left: 0px;
            top:0px;
        }
        #two{
            background-color: yellow;
            left: 50px;
            top:50px;
        }
        #three{
            background-color: blue;
            left: 100px;
            top:100px;
        }
        #four{
            background-color: purple;
            left: 150px;
            top:150px;
        }
    </style>
</head>
<body>
    <div id="main">
        <div id="one" class="child"></div>
        <div id="two" class="child"></div>
        <div id="three" class="child"></div>
        <div id="four" class="child"></div>
    </div>
</body>
</html>

这里写图片描述

读者可以亲手试试,当设置了padding时,main的外边距实际上是外延的,而四个div将跟随着外边距一起外延,因此,此时慎用padding。

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值