css3复习P5(定位)

本文深入探讨CSS3的定位机制,包括静态定位、相对定位、绝对定位、固定定位和粘滞定位。重点讲解了绝对定位的参考点、子绝父相布局以及z-index的工作原理。此外,还提到了粘滞定位的使用条件及其在不同场景下的应用。
摘要由CSDN通过智能技术生成


定位是一种更高级的布局手段,通过定位可以将元素摆放到页面的任意位置
使用position来设置定位

偏移量:
当元素开启了定位之后,(position的值不是static 就表明开启了定位),可以通过偏移量来设置元素的位置;
可选值:
垂直方向:
top:定位元素和定位位置上边的距离,top值越大定位元素越向下移动;
bottom:定位元素和定位位置下边的距离,bottom值越大定位元素越向上移动
水平方向:
left:定位元素和定位位置左边的距离,left值越大定位元素越向右移动
right:定位元素和定位位置右边的距离,left值越大定位元素越向左移动

静态定位

是所有元素的默认定位方式。意味着将一个元素定位在默认文档流中。

position: static;

相对定位

相对定位就是相对于自己以前在标准流中的位置来移动;

相对定位注意点

相对定位是不脱离标准流的, 会继续在标准流中占用一份空间
①在相对定位中同一个方向上的定位属性只能使用一个
②由于相对定位是不脱离标准流的, 所以在相对定位中是区分块级元素/行内元素/行内块级元素
③由于相对定位是不脱离标准流的, 并且相对定位的元素会占用标准流中的位置, 所以当给相对定位 的元素设置margin/padding等属性的时会影响到标准流的布局

绝对定位

绝对定位就是相对于body来定位
​ position: absolute;

绝对定位参考点

​ 1.规律
默认情况下所有的绝对定位的元素, 无论有没有祖先元素, 都会以body作为参考点

​ 2.如果一个绝对定位的元素有祖先元素, 并且祖先元素也是定位流, 那么这个绝对定位的元素就会以定位流的那个祖先元素作为参考点。
​ 2.1只要是这个绝对定位元素的祖先元素都可以
​ 2.2指的定位流是指绝对定位/相对定位/固定定位
​ 2.3定位流中只有静态定位不行

​ 3.如果一个绝对定位的元素有祖先元素, 并且祖先元素也是定位流, 而且祖先元素中有多个元素都是定位流, 那么这个绝对定位的元素会以离它最近的那个定位流的祖先元素为参考点。

绝对定位注意点

​ 1.绝对定位的元素是脱离标准流
​ 2.绝对定位的元素是不区分块级元素/行内元素/行内块级元素
​ 3.如果一个绝对定位的元素是以body作为参考点, 那么其实是以网页首屏的宽度和高度作为参考点, 而不是以整个网页的宽度和高度作为参考点
​ 4.一个绝对定位的元素会忽略祖先元素的padding

绝对定位-子绝父相

​ 相对定位弊端:
​ 相对定位不会脱离标准流, 会继续在标准流中占用一份空间, 所以不利于布局界面
​ 绝对定位弊端:
​ 默认情况下绝对定位的元素会以body作为参考点, 所以会随着浏览器的宽度高度的变化而变化
子绝父相
​ 子元素用绝对定位, 父元素用相对定位

绝对定位水平居中

​ 只需要设置绝对定位元素的left:50%;
​ 然后再设置绝对定位元素的 margin-left: -元素宽度的一半px;

固定定位

​ position: fixed;
​ 固定定位和前面学习的背景关联方式很像, 背景定位可以让背景图片不随着滚动条的滚动而滚动, 而固定定位可以让某个盒子不随着滚动条的滚动而滚动。

​ 注意点:
​ 1.固定定位的元素是脱离标准流的, 不会占用标准流中的空间
2.固定定位和绝对定位一样不区分行内/块级/行内块级

粘滞定位

position: sticky;

结合了 position:relative 和 position:fixed 两种定位功能于一体的特殊定位,适用于一些特殊场景。

元素定位表现为在跨越特定阈值前为相对定位,之后为固定定位。

​ 设置了position: sticky的元素并不脱离文档流,仍然保留元素原本在文档流中的位置。

​ 当元素在容器中被滚动超过指定的偏移值时,元素在容器内固定在指定位置。

​ 亦即如果设置了top: 50px,那么在sticky元素到达距离相对定位的元素顶部50px的位置时固定,不再向上

​ 移动(此时相当于fixed定位)。

​ 设置 position:sticky 同时给一个 (top,bottom,right,left) 之一即可

使用条件:

父元素不能overflow:hidden或者overflow:auto属性。

​ 必须指定top、bottom、left、right4个值之一,否则只会处于相对定位

​ 父元素的高度不能低于sticky元素的高度

​ sticky元素仅在其父元素内生效

z-index

默认情况下所有的元素都有一个默认的z-index属性, 取值是0.
​ z-index属性的作用是专门用于控制定位流元素的覆盖关系的

​ 2.默认情况下定位流的元素会盖住标准流的元素
​ 3.默认情况下定位流的元素后面编写的会盖住前面编写的
​ 4.如果定位流的元素设置了z-index属性, 那么谁的z-index属性比较大, 谁就会显示在上面
​ 注意点:
​ 1.从父现象
​ 1.1如果两个元素的父元素都没有设置z-index属性, 那么谁的z-index属性比较大谁就显示在上面。
​ 1.2如果两个元素的父元素设置了z-index属性, 那么子元素的z-index属性就会失效, 也就是说 谁的父元素的z-index属性比较大谁就会显示在上面。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值