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

需求:首先有个父级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
    评论
在CSS中,可以使用`position: absolute`和`position: relative`属性来实现相对定位和绝对定位。当一个元素的`position`属性设置为`absolute`时,它会相对于最近的已定位祖先元素进行定位。已定位祖先元素是指设置了`position`属性为`relative`、`absolute`或`fixed`的元素。 因此,如果要相对于父级父级进行定位,可以将父级元素的`position`属性设置为`relative`,然后在子元素中设置`position: absolute`,并使用`top`、`left`、`right`、`bottom`属性来确定子元素的位置。例如: HTML代码: ``` <div class="grand-parent"> <div class="parent"> <div class="child"> 这是一个子元素 </div> </div> </div> ``` CSS代码: ``` .grand-parent { position: relative; /* 父级元素设置为相对定位 */ width: 500px; height: 500px; background-color: #eee; } .parent { position: relative; /* 子元素设置为相对定位 */ width: 300px; height: 300px; background-color: #ccc; } .child { position: absolute; /* 子元素设置为绝对定位 */ top: 50px; /* 相对于父级父级向下偏移50px */ left: 50px; /* 相对于父级父级向右偏移50px */ width: 100px; height: 100px; background-color: #f00; } ``` 这里的`.grand-parent`元素父级父级元素,它的`position`属性设置为`relative`,并且它的子元素`.parent`的`position`属性也设置为`relative`。在`.child`元素中,使用`top`和`left`属性相对于`.grand-parent`元素进行定位,从而实现相对于父级父级进行定位

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值