css position相对定位与绝对定位彻底搞懂
position 属性的值
static---默认值relative---相对定位absolute---绝对定位fixed---固定定位sticky---粘性定位(本文不讲这个)
position:static
- 该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。
- 此时
toprightbottomleft和z-index属性无效。
position:relative
- 该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。
- 注意:元素并未脱离文档流
.box {
width: 100px;
height: 100px;
background: lightgreen;
color: #000;
border: 1px solid #ccc;
}
#two {
position: relative;
top: 20px;
left: 20px;
background: lightcoral;
}
#outer {
margin: 0 auto;
width: 500px;
height: 500px;
border: 1px solid #000;
}
<div id="outer">
<div class="box" id="one">One</div>
<div class="box" id="two">Two</div>
<div class="box" id="three">Three</div>
<div class="box" id="four">Four</div>
</div>

我们在图中可以看到,two元素相对于自身原来的位置进行了调整,但并没有影响到其他元素。
发现一个问题:看下图


一开始的css中我们使用了top:20px和left:20px将two元素进行了调整,通过上图就会发现这两个20px并不属于盒子模型,他只是用定位将two元素进行了位置调整。
接下来我们在其他不改变的情况下将top:20px和left:20px 换为 margin-top: 20px和margin-left: 20px
#two {
position: relative;
/* top: 20px;
left: 20px; */
margin-top: 20px;
margin-left: 20px;
background: lightcoral;
}


与上面的使用top和left时我们发现有两点不同:
margin-top和margin-left的两个20px属于盒模型中的margin- 看蓝色框框标示的地方,
two元素强制将three元素向下撑了
position:absolute
- 绝对定位元素相对于最近的非
static祖先元素定位。当这样的祖先元素不存在时,则相对于 ICB(inital container block, 初始包含块(根元素所在的包含块))。 - 因为默认是
static所以一般我们使用绝对定位时给祖先元素(经常是父级元素)加上position:relative。 - 在布置文档流中其它元素时,绝对定位元素不占据空间。
- 绝对定位的元素则脱离了文档流。
什么是包含块?
- 包含块:包含块简单说就是定位参考框,或者定位坐标参考系,元素一旦定义了定位显示(相对、绝对、固定)都具有包含块性质,它所包含的定位元素都将以该包含块为坐标系进行定位和调整。
- 初始包含块:用户代理选择根元素作为包含块(称之为初始 containing block)。
.box {
background: lightgreen;
width: 100px;
height: 100px;
float: left;
color: white;
border: 1px solid #ccc;
}
#three {
position: absolute;
top: 20px;
left: 20px;
}
#outer {
position: relative;
margin: 0 auto;
width: 500px;
height: 500px;
border: 1px solid #000;
}
<div id="outer">
<div class="box" id="one">One</div>
<div class="box" id="two">Two</div>
<div class="box" id="three">Three</div>
<div class="box" id="four">Four</div>
</div>

我们给outer即one two three four 四个元素的父级元素加上了position:relative给three加了position: absolute并通过top: 20px left: 20px改变了它的位置,由效果图我们可以看到,three元素脱离了文档流(不占空间,不会影响其他元素),并相对于outer元素进行了位置调整。
position:fixed
- 固定定位与绝对定位相似,但元素的包含块为 viewport 视口(包含块由视口建立)。
- 常用于创建在滚动屏幕时仍固定在相同位置的元素。
#outer {
width: 200px;
height: auto;
margin: 0 auto;
}
#fix {
position: fixed;
top: 100px;
right: 0px;
width: 50px;
height: 100px;
background-color: aqua;
}
<div id="outer">
<p>《再别康桥》</p>
<p>作者: 徐志摩</p>
<p>轻轻的我走了, </p>
<p>正如我轻轻的来; </p>
<p>我轻轻的招手, </p>
<p>作别西天的云彩 </p>
<p>---</p>
<p>那河畔的金柳, </p>
<p>是夕阳中的新娘; </p>
<p>波光里的艳影, </p>
<p>在我的心头荡漾 </p>
<p>---</p>
<p>软泥上的青荇, </p>
<p>油油的在水底招摇;</p>
<p>在康河的柔波里, </p>
<p>我甘心做一条水草 </p>
<p>---</p>
<p>那榆荫下的一潭, </p>
<p>不是清泉,是天上虹; </p>
<p>揉碎在浮藻间, </p>
<p>沉淀着彩虹似的梦。 </p>
<p>---</p>
<p>寻梦?撑一支长篙,</p>
<p>向青草更青处漫溯;</p>
<p>满载一船星辉,</p>
<p>在星辉斑斓里放歌。</p>
<p>---</p>
<p>但我不能放歌, </p>
<p>悄悄是别离的笙箫; </p>
<p>夏虫也为我沉默, </p>
<p>沉默是今晚的康桥! </p>
<p>---</p>
<p>悄悄的我走了, </p>
<p>正如我悄悄的来; </p>
<p>我挥一挥衣袖, </p>
<p>不带走一片云彩。 </p>
</div>
<div id="fix"></div>

- 定位元素处于右上角,当浏览页面底部时,它相对于 viewport 视口仍处于同一位置。
- 我们只需要给要固定的元素加上
position: fixed在通过top或bottom和left或right调整位置就能实现固定元素的效果。
小技巧
- 给元素设置
position:fixed后再设置left:0和right: 0相当于给元素设置了width: 100%. - 有时给元素设置了
position:fixed后无法上下滚动, 同时给元素设置top 0 bottom 0解决.
css position相对定位与绝对定位彻底搞懂的更多相关文章
- 详解CSS的相对定位和绝对定位
CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left,right,bottom,to ...
- Web—12-详解CSS的相对定位和绝对定位
CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left,right,bottom,to ...
- 详解CSS的相对定位和绝对定位(讲得很详细)
详解CSS的相对定位和绝对定位 CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left ...
- css定位:相对定位、绝对定位、固定定位的区别与特性
css定位:相对定位.绝对定位.固定定位的区别与特性 原文地址:http://www.qingzhouquanzi.com/106.html css定位常用的有以下三种: 使用了定位的共同特性: 这三 ...
- css之position相对定位和绝对定位
一.position的四个值:static.relative.absolute.fixed. 绝对定位:absolute和fixed统称为绝对定位 相对定位:relative 默认值:static 二 ...
- CSS定位深入理解 完全掌握CSS定位 相对定位和绝对定位
其实前面的标准流和浮动流都很理解,就是定位不太好理解,特别是相对定位和绝对定位,很多刚开始学的同学不好区分.因此这里,小强老师和大家一起分享CSS定位的学习. 通过我们前面的学习,我们网页布局方法: ...
- CSS中相对定位与绝对定位
看了几个讲解定位的博客,觉得还不错,分享之: 博客一:http://blog.sina.com.cn/s/blog_4bcf4a5e010008o0.html 文章中,主要需要参考的有两点: 1,相对 ...
- CSS的相对定位和绝对定位(position)
什么是定位呢? 定位(position),故名思议,就是确定元素在页面中的位置. CSS的常用定位有两种,一种是相对定位,一种是绝对定位. 下面我们看例子 <html> <head& ...
- h5整理--详解css的相对定位和绝对定位
浏览器默认状态下position的属性默认值是static也就是没有定位,元素出现在正常的文档流中,这个时候给元素设置的left,right.bottom.top这些偏移属性是没有效果的,不会生效: ...
随机推荐
- Confluence 6 配置 Office 转换器
Office 连接器(Office Connector)允许 Confluence 用户能够查看和编辑从 Microsoft Office 和 Open Office 中导入并附加到页面的内容. Of ...
- vue 中axios 的基本配置和基本概念
axios的基本概念及安装配置方法 ajax:异步请求,是一种无需再重新加载整个网页的情况下,能够更新部分网页的技术 axios:用于浏览器和node.js的基于promise的HTTP客户端 a ...
- mvc 模式和mtc 模式的区别
首先说说Web服务器开发领域里著名的MVC模式,所谓MVC就是把Web应用分为模型(M),控制器(C)和视图(V)三层,他们之间以一种插件式的.松耦合的方式连接在一起,模型负责业务对象与数据库的映射( ...
- Niagara物联网框架机制一(笔记)
一.介绍: Niagara是Tridium公司研发的设计用于解决设备连接应的软件框架平台技术,应用框架是一个软件工程中的概念,不同于普通的软件,它是用于实现某应用领域通用完备功能的底层服务,使用这种框 ...
- 第四周学习总结-HTML
2018年8月5日 这是暑假第四周,这一周我在菜鸟教程网学到了许多HTML的知识.HTML编写网页不像C语言.Java语言那必须有主方法.主函数什么的,它基本上都是标签(元素),但是它可以与CSS(层 ...
- 优先选择nullptr而不是0和NULL
我们知道:0是一个int,而不是一个指针.如果C++在一个只有指针才能够使用的上下文中发现它只有一个0,那么它会勉强将0解释成空指针,但那时一种倒退行为.C++的主要方针是0就是一个int,而不是指针 ...
- MAC 调用GCC 提示xcrun: error: invalid active developer path
xcrun: error: invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun at: ...
- 向github上提交自己的project
参考博客:https://blog.csdn.net/m0_37725003/article/details/80904824 step I: 创建自己的github账户(username:fourm ...
- MVC开发中的常见错误-01未能加载文件或程序集“EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”或它的某一个依赖项。
错误信息:未能加载文件或程序集“EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089”或 ...
- 利用sqoop对mysql执行DML操作
业务背景 利用Sqoop对MySQL进行查询.添加.删除等操作. 业务实现 select操作: sqoop eval \ --connect jdbc:mysql://127.0.0.1:3306/m ...