ICode9

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

css子元素如何相对父元素定位?

2020-12-08 12:31:52  阅读:390  来源: 互联网

标签:定位 元素 relative 相对 position css absolute


在css中,可以使用position属性,通过给父元素设置相对定位“position:relative;”样式,给子元素设置绝对定位“position:absolute;”样式来实现子元素相对父级元素定位。



本教程操作环境:windows7系统、css2版,该方法适用于所有品牌电脑。

相关推荐:《编程视频课程》

css中子元素相对父元素定位的实现方法

父级元素 样式设置:

1

position:relative;

子元素样式:

1

position:absolute;

示例代码:

html结构

1

2

3
 




 



css

1

2

3

4

5

6

7

8

9

10

11

#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,那就相当于父元素的位置是没有变动的。

1606983358693844.jpg

标签:定位,元素,relative,相对,position,css,absolute
来源: https://blog.csdn.net/jycg789/article/details/110870719

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

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

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

ICode9版权所有