Position

CSS position属性用于指定一个元素在文档中的定位方式。toprightbottom 和 left 属性则决定了该元素的最终位置。

在分析position元素定位之前,先来说说什么是文档流?(自我理解)

浏览器在默认情况下规定一个块元素在父元素内排列规则:

  1. 元素从上到下、从左到右排列
  2. 一个块级元素独占一行
  3. 行内元素不会独占一行
  4. 浮动元素在一行排不下则换行继续浮动

position 属性的五个值:

  • static
  • relative
  • absolute
  • fixed
  • sticky

一、static(默认值)

该关键字指定元素使用 正常 的布局行为,即元素在文档常规流中当前的布局位置。此时 toprightbottomleft 和 z-index 属性无效

二、relative

relative:相对定位

该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会在此元素未添加定位时所在位置留下空白)。position:relative 对 table-*-group, table-row, table-column, table-cell, table-caption 元素无效

 语法:

div{
position:relative;
}

特点:

1. 参照相对没有定位前的自己

2. 有层级,后来居上-- 层级高

3. 占据自己原来的位置--在原来的文档流当中存在自己的位置

4. 不会改变元素的特征,行内还是行内,块级还是块级

5. 支持margin、padding、margin:auto

6. 不脱离文档流

三、absolute

absolute:绝对定位

元素会被移出正常文档流(脱离文档流),并不为元素预留空间,通过指定元素相对于最近的非 static 定位祖先元素的偏移,来确定元素位置。绝对定位的元素可以设置外边距(margins),且不会与其他边距合并。

语法:

div{
position:absolute
}

特点:

1. 脱离文档流

2. 提升层级不占原来的位置,后来者居上

3. 不支持margin:auto,支持margin

4. 参照物:默认参照body,绝对定位的元素位置相对于最近的 已定位 的祖先元素

5. 行内元素支持宽高,块级元素内容撑开宽高改变元素特性

6. 一般配合相对定位使用-- 父相子绝

四、fixed

fixed:固定定位

元素会被移出正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口(viewport)的位置来指定元素位置。元素的位置在屏幕滚动时不会改变。

语法:

div{
position:fixed
}

特点:

1.参照物:相对 浏览器窗口 定位!

2.脱离文档流,提升层级

3.不支持margin:auto

4.可以改变元素特性,行内->块级

五、sticky

sticky:粘性定位(基于用户的滚动位置来定位)

元素根据正常文档流进行定位,然后相对它的最近滚动祖先包括table-related元素,基于toprightbottom, 和 left的值进行偏移。偏移值不会影响任何其他元素的位置。

粘性定位的元素是依赖于用户的滚动,在 position:relative 与 position:fixed 定位之间切换,表现为在跨越特定阈值前为相对定位,之后为固定定位。

注意:只有指定 top, right, bottom 或 left 四个阈值其中之一,才可使粘性定位生效。否则其行为与相对定位相同。

语法:

div.sticky {
position: -webkit-sticky;
position: sticky;
top: 0;
}

---层级关系(z-index)

因为元素的定位与文档流无关,所以它们可以覆盖页面上的其它元素,这里 z-index 属性指定了一个元素的堆叠顺序(哪个元素应该放在前面,或后面)

  1. z-index--可以调换两个层的上下位置关系

  2. 值可为正也可为  ,值越大越在上面,默认为0

  3. 只能 同级元素对比

  4. z-index 只对 定位的元素有效,其他元素均无效

{
position:absolute;
left:0px;
top:0px;
z-index:-1; /* 置于底层 */
}

参考文档:

https://developer.mozilla.org/zh-CN/docs/Web/CSS/position

https://www.runoob.com/css/css-positioning.html

Position定位详解的更多相关文章

  1. CSS魔法堂:Position定位详解

    一.Position各属性值详解   1.  static :默认值,元素将按照正常文档流规则排列.   2.  relative :相对定位,元素仍然处于正常文档流当中,但可以通过left.top. ...

  2. css position定位详解

    position:static 默认方式: position:relative 相对定位,相对于原有位置进行移动,并且保留它在文件流中的占位: position:absolute 绝对定位,相对于最近 ...

  3. css相关,position定位详解

    CSS 有两个最重要的基本属性,前端开发必须掌握:display 和 position. display属性指定网页的布局.两个重要的布局,弹性布局flex和网格布局grid. 本文介绍非常有用的po ...

  4. css3——position定位详解

    最近热衷于前端的开发,因为突然发现虽然对于网站.应用来说,功能处于绝对重要的地位,但是用户体验对于用户来讲同样是那么的重要,可以说是第一印象.最近在开发当中发现以前对于css中的position的理解 ...

  5. 带你走进CSS定位详解

    学习CSS相关知识,定位是其中的重点,也是难点之一,如果不了解css定位有时候都不知道怎么用,下面整理了一下关于定位属性的具体理解和应用方案. 一:定位 定位属性列表 position top bot ...

  6. HTML中元素的position属性详解

    HTML中元素的position属性详解 转载自:https://blog.csdn.net/wangzunkuan/article/details/81540935   HTML中DOM元素有5种定 ...

  7. CSS进阶内容—浮动和定位详解

    CSS进阶内容-浮动和定位详解 我们在学习了CSS的基本知识和盒子之后,就该了解一下网页的整体构成了 当然如果没有学习之前的知识,可以到我的主页中查看之前的文章:秋落雨微凉 - 博客园 CSS的三种布 ...

  8. 小甲鱼PE详解之基址重定位详解(PE详解10)

    今天有一个朋友发短消息问我说“老师,为什么PE的格式要讲的这么这么细,这可不是一般的系哦”.其实之所以将PE结构放在解密系列继基础篇之后讲并且尽可能细致的讲,不是因为小甲鱼没事找事做,主要原因是因为P ...

  9. css 之position用法详解

    css  之position用法详解: http://www.jb51.net/web/77495.html

随机推荐

  1. [atAGC054F]Decrement

    令$a_{i}$和$b_{i}$分别为$A_{i}$和$B_{i}$减少的值,考虑判定$\{a_{i}\},\{b_{i}\}$能否被得到 结论:$\{a_{i}\},\{b_{i}\}$能否被得到当 ...

  2. [noi38]游戏

    用线段数维护一段区间内的两个信息:1.需要多少经验就可以让有一个人升级,2.等级和.单点修改直接暴力做就可以,区间修改考虑如果这个区间不会产生升级就不递归下去而是打上懒标记. 考虑这个算法的时间复杂度 ...

  3. 直接插入100w数据报错

    ### Cause: com.mysql.cj.jdbc.exceptions.PacketTooBigException: Packet for query is too large (77,600 ...

  4. 关于CSS的粘性定位sticky失效问题

    CSS的粘性定位sticky可以起到吸顶灯的作用,用法如下 <body> <div> <nav style="postion:sticky; top: 0;&q ...

  5. [ARC098B] Xor Sum 2

    关于异或运算和代数和运算有很不错的性质: \(xor_{i = 1} ^ {n}a_i \leq \sum_{i = 1} ^ n a_i\) 所以我们考虑一段区间按题目来说是合法的,即 \(xor_ ...

  6. MongoDB 安装/启动/基本操作命令

    1.MongoDB简介 MongoDB是一个基于分布式文件存储的数据库,由C++语言编写,旨在为WEB应用提供可扩展的高性能数据存储解决方案. MongoDB是一个介于关系型数据库和非关系数据库之间的 ...

  7. PCA方差解释比例求解与绘图?

    目录 主成分方差解释率计算 绘图示例 主成分方差解释率计算 通常,求得了PCA降维后的特征值,我们就可以绘图,但各个维度的方差解释率没有得到,就无法获得PC坐标的百分比. 有些工具的结果是提供了维度标 ...

  8. Docker将容器制作成镜像并提交到远程仓库

    Docker将容器制作成镜像并提交到远程仓库 步骤如下 先在dockerhub上创建一个自己的用户https://hub.docker.com/.或者在阿里云也可以. 2. 然后先创建一个空的镜像名. ...

  9. seqtk抽取测序数据

    做数据比较的时候,由于同一个样本测序数据量不一致,需要抽取数据,控制数据量基本一致. 自己写脚本速度较慢,后面发现一个不错的工具:seqtk 原始数据抽取 如果只控制原始数据量一致,过滤低质量数据后直 ...

  10. Python基础之列表内置方法

    目录 1. 列表 1.1 序列 1.2 通用的序列操作 1.3 列表的基本操作 1.4 列表方法 1. 列表 数据结构:以某种方式(如通过编号)组合起来的元素(如数,字符乃至其他数据结构)集合. 在p ...