加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

CSS中子元素相对父元素定位

发布时间:2023-10-16 15:29:17 所属栏目:语言 来源:
导读:这篇文章主要介绍“CSS中子元素相对父元素定位用什么方法”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS中子元素相对父元素定位用什么方法”
这篇文章主要介绍“CSS中子元素相对父元素定位用什么方法”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS中子元素相对父元素定位用什么方法”文章能帮助大家解决问题。
 
解决方案
 
在父元素中加入position:relative;
 
子元素中加入position:absolute; right:20px;
 
代码
 
html结构
 
<div id="div1">
 
<div id="div2"></div>
 
</div>
 
css
 
#div1{
 
width:500px;height:500px;
 
background-color:darkgray;
 
position:relative;
 
}
 
#div2{
 
width:30px;height:30px;
 
background-color:red;
 
position:absolute;
 
right:20px;
 
}
 
原理
 
浏览器渲染html,是有文档流的说法的,块级元素换行渲染,行内元素行内渲染,在这里,两个div都是块级元素,一个父,一个子,正常来说的渲染结果是父元素在浏览器左上角,子元素在父元素的左上角。
 
如果我们要对子元素相对父元素进行定位,就要用对position属性。
 
position属性值
 
属性值 描述
 
absolute 生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。
 
relative 生成相对定位的元素,相对于其正常位置进行定位。
 
我们知道,要使用相对于父元素的定位,肯定要使用absolute,为什么直接使用absolute不起作用?因为使用absolute相对于父元素定位,对父元素有一个要求,就是父元素的position不能是static,如果父元素的position是static那么就继续向上查找元素,知道找不position不为static的元素,对这个元素进行相对定位,所以,需要将父元素的position设置为relative,这样做是没有影响的,因为,relative只是相对于正常位置进行定位,正常位置就是所谓的文档流默认的输出位置,如果我们设置了position为relative而不设置偏移量x,y,那就相当于父元素的位置是没有变动的。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章