• 07-定位布局


    1.定位布局

    - 定位流分类
    1.1.静态定位
    1.2.相对定位
    1.3.绝对定位
    1.4.固定定位
    1.5.粘滞定位
    1.6.z-index
    - 1.1.静态定位( Static positioning)

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

    ​ position: static;

    - 1.2.什么是相对定位?( Relative positioning )

    ​ 相对定位就是相对于自己以前在标准流中的位置来移动
    ​ position: relative;
    ​ 使用top,right,bottom,left来控制

    - 相对定位注意点
    • 相对定位是不脱离标准流的, 会继续在标准流中占用一份空间
    • 在相对定位中同一个方向上的定位属性只能使用一个
    • 由于相对定位是不脱离标准流的, 所以在相对定位中是区分块级元素/行内元素/行内块级元素
    • 由于相对定位是不脱离标准流的, 并且相对定位的元素会占用标准流中的位置, 所以当给相对定位 的元素设置margin/padding等属性的时会影响到标准流的布局
    - 相对定位应用场景
    • 用于对元素进行微调
    • 配合后面学习的绝对定位来使用
    - 1.3.什么是绝对定位?(Absolute positioning)

    ​ 绝对定位就是相对于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;

    - 1.4.固定定位(Fixed positioning)

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

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

    - 1.5.粘滞定位( Sticky positioning )

    ​ 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元素仅在其父元素内生效

    - 1.6.z-index

    ​ 1.什么是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属性比较大谁就会显示在上面。

    复习

    1.BFC作用:
    1.避免外边距重叠
    2.清除浮动
    3.两列布局 左侧定宽 右侧自适应
    4.三列布局 左右定宽 中间自适应
    2.CSS布局方式 定位 position
    1.静态定位 position:static
    2.相对定位 position:relative
    1.不脱离文档流
    2.相对于自身在浏览中位置定位
    3.绝对定位 position:absolute
    1.脱离文档流 原先位置不保留 飘在文档流上方
    2.无论有没有祖先或者父元素 都相对于浏览器视口区域进行定位
    3.如果父元素或者祖先元素设置了定位 相对于父元素/祖先元素定位
    4.固定定位 position:fixed
    1.脱离文档流,原先位置不保留,飘在文档流上方
    2.相对于浏览器视口区域进行定位
    5.粘滞定位 position:sticky
    1.不脱离文档流
    2.没达到设置的阈值前是相对定位,达到设置阈值后是固定定位
    使用场景:
    1.二级菜单显示与隐藏 2.侧边栏粘滞定位
    z-index:
    更改元素堆叠顺序,一般情况下设置定位流元素
    1.兄弟元素同时开启定位流,谁的z-index的值大,谁的优先级高
    2.父子元素:
    1.同时设置,无论父元素z-index值多大,子元素优先级高
    2.如果只给父元素设置,子元素优先级高
    3.只给子元素设置z-index,值>0优先级高于父元素,值<0,优先级低于父元素
    3.Gitee 代码版本控制工具
    首次使用:
    1.初始化本地git仓库
    git init
    2.新建远程仓库
    3.全局配置用户名和邮箱(第一次使用gitee)
    git config --global user.name ‘xxx’
    git config --global user.email ‘xxxx’
    4.将代码提交到暂存区
    git add . / git add *
    5.将暂存区代码提交到本地仓库
    git commit -m ‘[xxxxxx]’
    6.将本地仓库和远程仓库进行绑定(第一次提交需要)
    git remote add origin xxx.git
    7.将代码提交到远程仓库
    git push origin master
    后续使用:
    git add .
    git commit -m ‘[xxx]’
    git push origin master
    其他命令:
    git clone xxx.git 克隆远程仓库
    git status 查看git提交状态
    git remote -v 查看已绑定远程仓库
    git pull origin master 更新远程仓库代码(加入远程仓库)
    4.如何实现元素水平垂直居中?
    1.给父元素设置padding,padding:(父height-子height)/2(上下) (父width-子width)/2(左右),给父元素设置为border-box
    2.通过margin挤压,给子元素设置margin:(父height-子height)/2(上下) (父width-子width)/2(左右) 给父元素设置一个边框
    3.子绝父相,子元素设置top,bottom,left,right全部为0 margin:auto
    4.子绝父相,子元素设置top:50%,left:50%,margin-left:-子元素宽度/2 margin-top:-子元素高度/2
    5.如何实现文本水平垂直居中?
    text-align:center
    line-height:height

  • 相关阅读:
    微信小程序的目录结构
    部署keepalived+LVS
    二十九、高级IO与多路转接之epoll&reactor(收官!)
    期权投资的优势有哪些方面?
    OneFlow源码解析:静态图与运行时
    音视频开发:直播推流技术指南
    推荐算法中CTR和CVR的ESMM模型pytorch实现
    uniapp 使用定时器和取消定时器
    JUC并发编程——8锁现象(基于狂神说的学习笔记)
    简单易懂的时序数据压缩算法分析
  • 原文地址:https://blog.csdn.net/qq_52342759/article/details/134056568