position 属性的值

  • static ---默认值
  • relative ---相对定位
  • absolute ---绝对定位
  • fixed ---固定定位
  • sticky ---粘性定位(本文不讲这个)

position:static

  • 该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。
  • 此时 top right bottom leftz-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:20pxleft:20pxtwo元素进行了调整,通过上图就会发现这两个20px并不属于盒子模型,他只是用定位将two元素进行了位置调整。

接下来我们在其他不改变的情况下将top:20pxleft:20px 换为 margin-top: 20pxmargin-left: 20px

#two {
position: relative;
/* top: 20px;
left: 20px; */
margin-top: 20px;
margin-left: 20px;
background: lightcoral;
}



与上面的使用topleft时我们发现有两点不同:

  • margin-topmargin-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>

我们给outerone two three four 四个元素的父级元素加上了position:relativethree加了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在通过 topbottomleftright 调整位置就能实现固定元素的效果。

小技巧

  • 给元素设置position:fixed后再设置 left:0right: 0 相当于给元素设置了 width: 100%.
  • 有时给元素设置了position:fixed后无法上下滚动, 同时给元素设置top 0 bottom 0 解决.

css position相对定位与绝对定位彻底搞懂的更多相关文章

  1. 详解CSS的相对定位和绝对定位

    CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left,right,bottom,to ...

  2. Web—12-详解CSS的相对定位和绝对定位

    CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left,right,bottom,to ...

  3. 详解CSS的相对定位和绝对定位(讲得很详细)

    详解CSS的相对定位和绝对定位 CSS的相对定位和绝对定位通常情况下,我们元素的position属性的值默认为static 就是没有定位,元素出现在正常的文档流中,,这个时候你给这个元素设置的left ...

  4. css定位:相对定位、绝对定位、固定定位的区别与特性

    css定位:相对定位.绝对定位.固定定位的区别与特性 原文地址:http://www.qingzhouquanzi.com/106.html css定位常用的有以下三种: 使用了定位的共同特性: 这三 ...

  5. css之position相对定位和绝对定位

    一.position的四个值:static.relative.absolute.fixed. 绝对定位:absolute和fixed统称为绝对定位 相对定位:relative 默认值:static 二 ...

  6. CSS定位深入理解 完全掌握CSS定位 相对定位和绝对定位

    其实前面的标准流和浮动流都很理解,就是定位不太好理解,特别是相对定位和绝对定位,很多刚开始学的同学不好区分.因此这里,小强老师和大家一起分享CSS定位的学习. 通过我们前面的学习,我们网页布局方法: ...

  7. CSS中相对定位与绝对定位

    看了几个讲解定位的博客,觉得还不错,分享之: 博客一:http://blog.sina.com.cn/s/blog_4bcf4a5e010008o0.html 文章中,主要需要参考的有两点: 1,相对 ...

  8. CSS的相对定位和绝对定位(position)

    什么是定位呢? 定位(position),故名思议,就是确定元素在页面中的位置. CSS的常用定位有两种,一种是相对定位,一种是绝对定位. 下面我们看例子 <html> <head& ...

  9. h5整理--详解css的相对定位和绝对定位

    浏览器默认状态下position的属性默认值是static也就是没有定位,元素出现在正常的文档流中,这个时候给元素设置的left,right.bottom.top这些偏移属性是没有效果的,不会生效: ...

随机推荐

  1. Android UiAutomator2.0

    一.环境搭建 JDK(java环境).SDK(adb appt环境),这两个已经不想再叙述了直接看详见--> android studio 安装,下载地址:https://developer.a ...

  2. Ribbon服务消费者

    springcloud使用到两种消费工具,ribbon和feign ribbon实现了服务的负载均衡 feign默认集成了ribbon,一般情况下使用feign作为消费端 搭建消费者项目(Ribbon ...

  3. Rsync 常见错误及解决方法

    由于阿里云SLB不提供ECS间的数据同步服务,如果部署在SLB后端ECS上的应用服务是无状态的,那么可以通过独立的ECS或RDS服务来存储数据:如果部署在SLB后端ECS上的应用服务是有状态的,那么需 ...

  4. 目标检测之选择性搜索-Selective Search

    一.滑动窗口检测器 一种用于目标检测的暴力方法就是从左到右,从上到下滑动窗口,利用分类识别目标.为了在不同观察距离处检测不同的目标类型,我们可以使用不同大小和宽高比的窗口 得到窗口内的图片送入分类器, ...

  5. SQL Server表关联

    表关联:Hash.Nested Loops.Merge.这是实际算法,不是T-SQL中的inner/left/right/full/cross join.优化器会把这些T-SQL写法转换成上面的3种算 ...

  6. Mongodb for .Net Core 封装类库

    一:引用的mongodb驱动文件版本为 Mongodb.Driver 20.4.3 二:我只是进行了常用方法的封装,如有不当之处,请联系我 创建mongodb的连接 using MongoDB.Bso ...

  7. ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN DESC)函数的使用

    ROW_NUMBER() OVER(PARTITION BY COLUMN ORDER BY COLUMN DESC)函数的作用是指定COLUMN(列)进行分区,在分区内指定COLUMN(列)进行排序 ...

  8. WARN conf.FlumeConfiguration: Could not configure sink sink1 due to: No channel configured for sink: sink1 org.apache.flume.conf.ConfigurationException: No channel configured for sink: sink1

    1.错误如下所示,启动flume采集文件到hdfs案例的时候,出现如下所示的错误: 大概是说No channel configured for sink,所以应该是sink哪里配置出现了错误,百度了一 ...

  9. Linux 的文件类型

    Linux 的文件通常分为 7 大类 文件类型                                  缩写      英文名称                                ...

  10. 【C#】WebApi 添加过滤器,实现对请求参数和响应内容的日志记录

    filter的介绍 filter在Web API中经常会用到,主要用于记录日志,安全验证,全局错误处理等:Web API提供两种过滤器的基本类型:actionfilterattribute,excep ...