07-定位布局

定位布局

    • 1.定位布局
        • - 定位流分类
          • 1.1.静态定位
          • 1.2.相对定位
          • 1.3.绝对定位
          • 1.4.固定定位
          • 1.5.粘滞定位
          • 1.6.z-index
        • - 1.1.静态定位( Static positioning)
        • - 1.2.什么是相对定位?( Relative positioning )
          • - 相对定位注意点
          • - 相对定位应用场景
        • - 1.3.什么是绝对定位?(Absolute positioning)
          • - 绝对定位参考点
          • -绝对定位注意点
          • - 绝对定位-子绝父相
          • -绝对定位水平居中
        • - 1.4.固定定位(Fixed positioning)
        • - 1.5.粘滞定位( Sticky positioning )
          • 使用条件:
        • - 1.6.z-index

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/120933.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink on yarn 加载失败plugins失效问题解决

Flink on yarn 加载失败plugins失效问题解决 flink版本&#xff1a;1.13.6 1. 问题 flink 任务运行在yarn集群,plugins加载失效,导致通过扩展资源获取任务参数失效 2. 问题定位 yarn容器的jar包及插件信息,jar包是正常上传 源码定位 加载plugins入口&#xff0c;TaskMana…

Unity的屏幕坐标获取

Screen.width public static int width ; 描述 屏幕窗口的当前宽度(以像素为单位)(只读)。 此为玩家窗口的实际宽度(在全屏模式下,它也是当前分辨率)。 using System.Collections; using System.Collections.Generic; using UnityEngine;public class Example : Mo…

TCP三次握手具体过程

四次挥手 1&#xff09;客户端进程发出连接释放报文&#xff0c;并且停止发送数据。释放数据报文首部&#xff0c;FIN1&#xff0c;其序列号为sequ&#xff08;等于前已经传送过来的数据的最后一个字节的序号加1)&#xff0c;此时&#xff0c;客户端进入FIN_WAIT_1&#xff08…

【Python机器学习】零基础掌握RandomTreesEmbedding集成学习

如何在高维数据中找到隐藏的结构? 面临大量复杂、高维的数据,例如社交网络分析、电子商务推荐系统或医疗诊断,如何有效地分析和解读这些数据成为一大挑战。一个有效的方法是使用嵌入技术将高维数据转化为低维形式,同时保留其内在结构。这次将介绍一种称为“随机树嵌入”(…

AI新能量!FortiGate NGFW面向数据中心全面集成FortiGuard AI 安全服务

企业IT技术正在以惊人的速度发展&#xff0c;转型最大的领域之一是下一代防火墙&#xff08;NGFW&#xff09;市场。如今&#xff0c;混合云、多云、边缘等多种基础设施形态共存&#xff0c;已经成为大部分企业的常态&#xff0c;不断扩张的攻击面需要不同形态防火墙的安全防护…

若依ruoyi-nbcio如何做一个仿钉钉流程设计器的思考

更多ruoyi-nbcio功能请看演示系统 gitee源代码地址 前后端代码&#xff1a; https://gitee.com/nbacheng/ruoyi-nbcio 演示地址&#xff1a;RuoYi-Nbcio后台管理系统 看到有些流程图采用仿钉钉的流程设计&#xff0c;比如下面界面&#xff1a; 这种方式虽然简单&#xff0c…

kafka安装配置

Kafka的安装配置可以按照以下步骤进行&#xff1a; 确保已安装Java运行环境&#xff1a;Kafka是使用Java语言编写的&#xff0c;因此需要在安装Kafka之前先安装Java运行环境。Kafka支持Java 8及以上版本。硬件要求&#xff1a;Kafka可以在任何硬件上运行&#xff0c;但是在生产…

计算机网络文章荟萃

脑残式网络编程入门(二)&#xff1a;我们在读写Socket时&#xff0c;究竟在读写什么&#xff1f;-网络编程/专项技术区 - 即时通讯开发者社区! 1.什么是 socket - 掘金2.socket 的实现原理 - 掘金本文讲述了 socket 在 linux 操作系统下的数据结构&#xff0c;以及阻塞 IO 利用…

【Java】PAT Basic Level 1023 组个最小数

题目 1024 组个最小数 作者 CAO, Peng 单位 Google 给定数字 0-9 各若干个。你可以以任意顺序排列这些数字&#xff0c;但必须全部使用。目标是使得最后得到的数尽可能小&#xff08;注意 0 不能做首位&#xff09;。例如&#xff1a;给定两个 0&#xff0c;两个 1&#xff…

檢測項目簡體字

某些項目可能要求代碼中不允許使用簡體字 安裝stcheck檢查 yarn add stcheck --dev在項目根目錄創建 st.config.json 文件 {"patterns": ["./**/*.(ts|js|tsx|jsx|vue|html)","!**/node_modules/**","!.git/**"],"gitignore&q…

Express框架开发接口之登录与注册API

我们利用nodeexpressmysql开发接口&#xff0c;对数据库数据进行简单增、删、查改等操作。 接口是什么&#xff1f; 接口是 前后端通信的桥梁 简单理解&#xff1a;一个接口就是 服务中的一个路由规则 &#xff0c;根据请求响应结果 接口的英文单词是 API (Application Progra…

【socket】网卡内部缓冲区、socket缓冲区、滑动窗口

一、网卡内部缓冲区 网卡内部的缓冲区&#xff0c;通常称为环形缓冲区&#xff08;Ring Buffer&#xff09;。环形缓冲区是一种用于数据存储和数据传输的结构&#xff0c;它允许数据在网络接口卡&#xff08;网卡&#xff09;和计算机操作系统之间进行高效传输。 当网卡接收到…

Java工具库——FastJson的40个常用方法

那些想看却没看的书&#xff0c;在心里摆满一个图书馆… 工具库介绍 阿里巴巴的 FastJSON&#xff0c;也被称为 Alibaba FastJSON 或阿里巴巴 JSON&#xff0c;是一个高性能的 Java JSON 处理库&#xff0c;用于在 Java 应用程序中解析和生成 JSON 数据。FastJSON 以其卓越的性…

C++:string的使用

目录 1、string的介绍 2、string的初始化 2.1、方法1 2.2、方法2 2.3、方法3 2.4、方法4 2.5、方法5 2.6、方法6 3、string的赋值运算符重载 4、 string的常用内置函数使用 5、string的遍历 4.1数组下标访问 4.2迭代器 4.3范围for 6、模拟实现MyString 6.1、头文…

HTTP发起请求与收到响应的大致过程

可以《《透视 HTTP 协议》Windows 10 搭建最小实验环境》搭建环境&#xff0c;之后才能进行下边的操作。 1.鼠标左键点击两下www目录下的start.bat批处理文件。 2.打开Wireshark&#xff0c;然后选择Adapter for loopback traffic capture。 3.然后把tcp.port 80 || udp.…

碳排放数据,各地区的(直辖市数据细分到区县),含shp和xlsx格式,带符号化

这两天推了道路相关的数据&#xff0c;道路线路、客运飞机场、航空、地铁、火车站点等等交通出行类的数据之前都已发过&#xff0c;需要的可以自己翻一翻。 交通运输行业还比较关注的碳排放数据&#xff0c;也整理出来了&#xff0c;有需要的自取。 数据地址&#xff1a; 全…

项目管理工具ConceptDraw PROJECT mac中文版自定义列功能

ConceptDraw PROJECT Mac是一款专业的项目管理工具&#xff0c;适用于MacOS平台。它提供了成功规划和执行项目所需的完整功能&#xff0c;包括任务和资源管理、报告和变更控制。 这款软件可以与ConceptDraw office集成&#xff0c;利用思维导图和数据可视化的强大功能来改进项目…

Microsoft.Extensions 简介

Microsoft.Extensions 简介 一、Microsoft.Extensions 简介 .NET Extensions 是一套官方的、开源的、跨平台的 API 集合&#xff0c;提供了一些常用的编程模式和实用工具&#xff0c;例如依赖项注入、日志记录、缓存、Host以及配置等等。该项目的大多数 API 都被用在 .NET 平…

Python的快捷键

Python Python使用的小快招关于注释关于格式写主函数如何看函数源代码 Python使用的小快招 本文主要记录了写python代码的时候提高效率的一些小妙招 关于注释 选中要注释的代码&#xff0c;然后按下Ctrl /即可对多段代码注释。 关于格式 对于python代码的格式&#xff0c…

Jetpack:019-Jetpack的导航二(传递数据)

文章目录 1. 知识回顾2. 使用方法2.1 通过参数传递数据2.2 获取参数中的数据2.3 共享导航控制器 3. 示例代码4. 内容总结 我们在上一章回中介绍了Jetpack中导航相关的内容&#xff0c;本章回中 继续介绍导航相关的内容。闲话休提&#xff0c;让我们一起Talk Android Jetpack吧…