作者:WangMin

格言:努力做好自己喜欢的每一件事

在讲几种定位方式之前,我们先来了解一下什么是普通流(normal flow)

除非专门指定,否则所有框都在普通流中定位。普通流中元素框的位置由元素在(X)HTML中的位置决定。块级元素从上到下依次排列,框之间的垂直距离由框的垂直margin计算得到。行内元素在一行中水平布置。

position 属性的作用

position 用于定位盒子对象,有时一个布局中几个小对象,不易用css padding、css margin 进行定位,这个时候我们就可以使用 position 定位来搞定。特别是一个盒子里几个小盒子不规律的布局,这个时候我们使用 position 定位非常方便布局对象。

position 属性用来指定一个元素在网页上的位置,一共有5种定位方式,也就是说 position 属性主要有五个属性值。如下:

属性值 含义
static 默认值
relative 相对定位
absolute 绝对定位
fixed 固定定位
sticky 粘性定位

元素可以使用的顶部(top),底部 (bottom),左侧 (left),右侧 (right)及 z-index 属性定位。然而,这些属性无法工作,除非是先设定position属性。他们也有不同的工作方式,这取决于定位方法。

position:static

staticposition 属性的默认值。如果省略 position属性,浏览器就认为该元素是 static定位。

这时,浏览器会按照源码的顺序,决定每个元素的位置,这称为"正常的页面流"(normal flow)。每个块级元素占据自己的区块(block),元素与元素之间不产生重叠,这个位置就是元素的默认位置。

注意,static定位所导致的元素位置,是浏览器自主决定的,所以这时top、bottom、left、right、 z-index这五个属性无效。

position:relative

相对定位的偏移参考元素是元素本身,不会使元素脱离文档流。用相对定位的元素不管它是否进行移动,元素仍要占据它原来的位置。移动元素会导致它覆盖其他的框。相对定位元素常常作为绝对定位元素的父元素。并且定位元素经常与z-index属性进行层次分级。它必须搭配top、bottom、left、right这四个属性一起使用,用来指定偏移的方向和距离。例子如下:

没有使用position:relative时:

<div class="box">
<div class="same one"></div>
</div>
.box{
width:200px;
border:1px solid #ccc;
}
.box>.same{
width:200px;
height:200px;
line-height: 50px;
text-align: center;
color: azure;
margin-bottom: 20px;
} .box>.one{
background:#CCCCCC;
}



使用position:relative时:

.box>.one{
background:#CCCCCC;
position: relative;
top: 10px;
left:10px;
}





我们使用了 top:10px 和 left:10px 将 one元素进行了调整,通过上图就会发现这两个10px并不属于盒子模型,他只是用定位将 one元素进行了位置调整。上面代码中,div元素从默认位置向下偏移10px(即距离顶部10px),向右偏移10排序(即距离左边10px)。

position:absolute

它有一个重要的限制条件:相对于已定位的最近的祖先元素,如果没有已定位的最近的祖先元素,那么它的位置就相对于最初的包含块(如body)。另外,absolute定位也必须搭配top、bottom、left、right这四个属性一起使用。

绝对定位的框脱离普通流,所以它可以覆盖页面上的其他元素,可以通过设置Z-Iindex属性来控制这些框的堆放次序。

<div class="box">
<div class="same one"></div>
<div class="same two"></div>
<div class="same three"></div>
</div>
.box{
width:200px;
border:1px solid #ccc;
}
.box>.same{
width:200px;
height:200px;
line-height: 50px;
text-align: center;
color: azure;
margin-bottom: 20px;
} .box>.one{
background:#CCCCCC;
}
.box>.two{
background:pink;
}
.box>.three{
background:burlywood;
}

正常文档流显示的效果:

未给父级元素 .box 添加相对定位,给 .two 元素设置绝对定位例子如下:

.box>.two{
background:pink;
position: absolute;
top:20px;
left:20px;
}



以上例子可以看出由于未给父级元素 .box 添加相对定位,给 .two 元素设置绝对定位,使的 .two 脱离了普通流,原来的位置没有保留,而且将 .one 覆盖,并对文档的根元素进行了绝对定位,定位于距离文档根元素顶部20px,左侧20px的位置。

给父级元素 .box 添加相对定位,然后再给 .two 元素设置绝对定位例子如下:

.box{
width:200px;
border:1px solid #ccc;
position: relative;
}
.box>.two{
background:pink;
position: absolute;
top:20px;
left:20px;
}



以上例子可以看出 .two 元素相对于父元素 .box 进行了绝对定位,使的 .two 脱离了普通流,原来的位置没有保留,还将 .one 覆盖,并且 .two 元素定位于距离父元素 .box 顶部20px,左侧20px的位置。

从以上例子中可以得出一个结论,如果想要子元素定位于父元素的某个位置,必须给父元素设置一个相对定位 position:relative,才能使子元素出现在父元素的正确位置。

position:fixed

fixed表示,相对于视口(viewport,浏览器窗口)进行偏移,即定位基点是浏览器窗口。这会导致元素的位置不随页面滚动而变化,好像固定在网页上一样。 常用于创建在滚动屏幕时仍固定在相同位置的元素。如果想要某个元素固定在页面的某个位置不动的话,就个这个元素设置 position:fixed,并通过 top bottomleftright 调整位置就能实现固定元素的效果。

position:sticky

sticky 跟前面四个属性值都不一样,它会产生动态效果,很像 relativefixed 的结合:一些时候是relative定位(定位基点是自身默认位置),另一些时候自动变成fixed定位(定位基点是视口)。

因此,它能够形成"动态固定"的效果。例子如下,初始加载时在自己的默认位置(relative定位)。

<div class="box box11">111111</div>
<div class="box box1 active">222222</div>
<div class="box box2">333333</div>
<div class="box box3">444444</div>
<div class="box box4">555555</div>
<div class="box box5">666666</div>
.box{
width:50%;
height:400px;
color:#fff;
margin-bottom: 20px;
}
.box11{
background:#f00;
}
.box1{
background:#000;
}
.box2{
background:palegoldenrod;
}
.box3{
background:peru;
}
.box4{
background:blueviolet;
}
.box5{
background:burlywood;
}
.active{
position:sticky;
top:0px;
}

页面向下滚动时,工具栏变成固定位置,始终停留在页面头部(fixed定位)。

等到页面重新向上滚动回到原位,工具栏也会回到默认位置。

sticky 生效的前提是,必须搭配topbottomleftright 这四个属性一起使用,不能省略,否则等同于relative定位,不产生"动态固定"的效果。原因是这四个属性用来定义"偏移距离",浏览器把它当作 sticky 的生效前提。

它的具体规则是,当页面滚动,父元素开始脱离视口时(即部分不可见),只要与 sticky 元素的距离达到生效前提,relative 定位自动切换为 fixed 定位;等到父元素完全脱离视口时(即完全不可见),fixed 定位自动切换回relative 定位。

sticky属性有以下几个特点

1、该元素并不脱离文档流,仍然保留元素原本在文档流中的位置。

2、当元素在容器中被滚动超过指定的偏移值时,元素在容器内固定在指定位置。即如果你设置了top: 20px,那么在sticky元素到达距离相对定位的元素顶部20px的位置时固定,不再向上移动。

3、元素固定的相对偏移是相对于离它最近的具有滚动框的祖先元素,如果祖先元素都不可以滚动,那么是相对于浏览器窗口来计算元素的偏移量。

position:sticky使用条件:

1. 父元素不能设置 overflow:hidden; 或者 overflow:auto;  属性;
2. 必须制定 top、bottom 、left 、 right 4个值之一,否则只会处于相对定位;
3. 父元素的高度不能低于sticky 元素的高度;
4. sticky 元素仅在其父元素内生效;

position:sticky 这个属性的兼容性还不是很好,目前仍是一个试验性的属性,并不是W3C推荐的标准。具体情况可以如下图:


以上仅是个人见解,若有不足之处欢迎在下方评论指出,那就先分享到这里!! 后续继续更新!!

CSS属性 Position的几种定位方式的更多相关文章

  1. css中对position的几种定位方式的最佳诠释

    关于元素的position定位的理解,牛客网的hardy给出了一个比较好的理解: 在html中网页可以看成一个立体的空间,一个完整的页面是由很多个页面堆积形成的,如上图所示   CSS中Positio ...

  2. CSS中position的4种定位详解

    大家都知道,css中的position有4种取值,分别是static.fixed.relative.absolute. 详细解释: static:相当于没有定位,元素会出现在正常的文档流中. fixe ...

  3. position的四种定位方式:static、fixed、relative、absolute

    position属性用来规定元素的定位类型和方式 ①position:static 默认值,没有定位,元素出现在正常的流中: ②position:fixed  固定定位 是相对于浏览器窗口来进行定位: ...

  4. CSS 浅析position:relative/absolute定位方式

    ## 一.position:relative 相对定位 ## 分两种情况分析: · 无 position: relative: · 有 position: relative. 代码如下图: 显示效果如 ...

  5. CSS的五种定位方式

    CSS中一共有五种定位: position:static:默认值 position:absolute:绝对定位 position:relative:相对对定位 position:fixed:固定定位 ...

  6. Selenium 之18 种定位方式

    1 id 定位 driver.find_element_by_id() HTML 规定id 属性在HTML 文档中必须是唯一的.这类似于公民的身份证号,具有很强的唯一性 from selenium i ...

  7. Selenium学习之==>18种定位方式的使用

    Selenium的定位方式一共有18种,单数8种,复数8种,最后两种是前面这16种的底层封装 单数形式8种 # 1.id定位 al = driver.find_element_by_id('i1') ...

  8. selenuim中18种定位方式

    18种定位方式=8种单数形式+8种复数形式+2种底层方案 单数可以确定唯一,复数无法确定: 单数形式定位,返回的是一个元素,复数形式,返回的是一个列表,返回的是当前页面所有符合要求的元素,没有意义 一 ...

  9. 关于css在html的三种使用方式

    关于css在html的三种使用方式 1.内联样式(直接在html里面使用style) eg:<h1 style="color:skyblue">这是一个测试标题< ...

  10. Android中几种定位 方式

    介绍的几种定位方式 http://www.cnblogs.com/cuihongyu3503319/p/3863867.html 百度地图api: http://lbsyun.baidu.com/in ...

随机推荐

  1. Git子模块使用说明

    介绍 前端不同应用存在公共的脚本或样式代码,为了避免重复开发,将公共的代码抽取出来,形成一个公共的 git 子模块,方便调用和维护. 软件架构 本仓库代码将作为 git 子模块,被引用到其他仓库中,不 ...

  2. 关于 yield 关键字(C#)

    〇.前言 yield 关键字的用途是把指令推迟到程序实际需要的时候再执行,这个特性允许我们更细致地控制集合每个元素产生的时机. 对于一些大型集合,加载起来比较耗时,此时最好是先返回一个来让系统持续展示 ...

  3. Qt+GDAL开发笔记(一):在windows系统mingw32编译GDAL库、搭建开发环境和基础Demo

    前言   麒麟系统上做全球北斗定位终端开发,调试工具要做一个windows版本方便校对,北斗GPS发过来的是大地坐标,应用需要的是经纬度坐标,所以需要转换,可以使用公式转换,但是之前涉及到了另一个sh ...

  4. DevOps|研发效能治理:进化史、规模化与治理复杂性

    麻广广@码猿外 研发效能这个词近几年火遍全网,各大企业都加入了研发效能治理的行列,开始梳理企业内部各个团队的研发流程,以期望找到企业降本增效的方向. 抛开政治因素,研发效能治理我们到底是在谈什么呢?从 ...

  5. 基于C#的窗体阴影效果方案 - 开源研究系列文章

    最近在研究C#的Winform窗体的效果,上次介绍了窗体动画效果的博文( 基于C#的无边框窗体动画效果的完美解决方案 - 开源研究系列文章 ),这次将窗体阴影效果的方案进行一个介绍. 找了一下度娘,具 ...

  6. CentOS7系统初始化个人配置

    以下内容为个人最小化安装后的配置步骤 更换yum源为阿里云 yum install -y epel-release lrzsz wget yum-axelget mv /etc/yum.repos.d ...

  7. Programming abstractions in C阅读笔记:p88-p90

    <Programming Abstractions In C>学习第44天,p88-p90总结. 一.技术总结 1.内存分配 内存分配可以分为:static allocation.auto ...

  8. LeetCode 周赛上分之旅 #39 结合中心扩展的单调栈贪心问题

    ️ 本文已收录到 AndroidFamily,技术和职场问题,请关注公众号 [彭旭锐] 和 BaguTree Pro 知识星球提问. 学习数据结构与算法的关键在于掌握问题背后的算法思维框架,你的思考越 ...

  9. 白话领域驱动设计DDD

    容我找个借口先,日常工作太忙,写作略有荒废.一直想聊下领域驱动设计,以下简称DDD,之前也看过一些教程,公司今年两个项目--银行核心和信用卡核心,都深度运用DDD成功落地,有人说DDD挺难理解,在此讲 ...

  10. uwsgi配置

    编辑nginx配置: server { listen 8098; server_name 127.0.0.1; location / { include uwsgi_params; # uwsgi_p ...