解决方案
在父元素中加入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,那就相当于父元素的位置是没有变动的。
到此这篇关于css子元素相对父元素进行定位的实现的文章就介绍到这了,更多相关css子元素相对父元素定位内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
首先提示,处于安全的需要JavaScript不能直接访问本地资源文件,那怎么办呢?下...
1. 给logo添加替代文本 这样有两个好处:屏幕阅读器能识别logo图片代表的含义,...
em是何物? em指字体高,任意浏览器的默认字体高都是16px。所以未经调整的浏览器...
用什么代码实现?不允许有白色底色产生,因为手机高度不一样 设计图要标准(750...
大家好,我是民工哥。 一提到监控系统,大家很快就能想到 Zabbix 、 Prometheu s...
问题描述 按钮样式为图标+文字,在使用flex布局写垂直居中时,iphone7手机上文字...
最近在开发中遇到的需求是:微信扫描课件二维码,播放其对应的课件视频 设计流程...
复制代码 代码如下: html !--混合框架的布局: 要想实现复杂的页面布局,只需在f...
创业公司常常能给我们带来惊喜,不拘一格的工作方式,别开生面的商业模式,独树...
一、前言 在了解加密原理前,我们来看看这样一个故事。 小红和小明是情侣,一天...