CSS 定位

为什么需要浮动?

我们在访问一些网站的时候, 经常会遇到如下这种情况, 有一个组件, 一直固定在屏幕的固定位置, 无论你如何滑动这个网页, 就会固定在哪里, 如下, 下图是王者荣耀的一个官网:
王者荣耀官网
要实现上面的效果, 标准流或者是浮动是无法快速实现的, 此时就需要使用定位来实现.
因此, 定位和浮动之间的一些区别如下 :

  • 浮动可以让多个块级盒子在一行没有间隙的排列显示, 可以用于纵向排列的盒子
  • 定位则是可以让盒子自由地在某个盒子内移动, 或者是固定屏幕中某个位置, 并且可以压住其他盒子.

定位的组成

  • 定位: 将一个盒子固定在某个位置, 所以定位也是在摆盒子, 按照定位的方式移动盒子.
  • 定位 = 定位模式 + 边偏移
  • 定位模式: 用于指定一个元素在文档中定位的方式
  • 边偏移: 决定了该元素的最终位置

定位模式

定位模式决定元素的定位方式, 通过css中的position属性来决定, 其值可以分为四个:

  • static : 静态定位
  • relative : 相对定位
  • absolute : 绝对定位
  • fixed : 固定定位

static

静态定位. 静态定位就是元素默认的定位方式, 也就是无定位.
语法:

选择器 {position: static; /*默认值, 无定位, 标准流*/
}

可以理解为:

  • 静态定位就是标准流, 没有边偏移
  • 静态定位在布局的时候很少用

relative

相对定位是元素在移动的时候, 是相对于它原来的位置来说的.
例如下面有一个盒子如下:
在这里插入图片描述
它丁顶着浏览器窗口的左上角, 现在给他设置position: relative.
想让他定位, 只有定位模式position还不够, 还需要边偏移:

div {postion: relative;top: 100px;
}

在这里插入图片描述
然后给他加上一个left 100px:

div {postion: relative;top: 100px;left: 100px;
}

其效果如下:
在这里插入图片描述
相对定位总是以自己原来的位置为基础来进行边偏移.
在这里插入图片描述

同时, 虽然这个盒子通过定位走了, 假如在文档中, 它下面还定义了一个div盒子, 那么浮动的盒子还是继续占有原来的位置, 继续以标准流的方式占有它.
在这里插入图片描述
总结:

  • 人走了, 这个位置还是继续被相对定位的盒子占有
  • 相对定位是相对自己原来在文档中的位置进行定位的.

absolute

绝对定位, 元素在移动的时候, 是相对于它祖先元素来定位的.
语法:

选择器 {position: absolute;
}

分为两种情况:

  • 如果没有父元素, 或者是父元素没有定位, 则以浏览器定位为主
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.test {position: absolute;width: 100px;height: 100px;top: 100px;left: 100px;background-color: pink;}</style>
</head>
<body><div class="test"></div>
</body>
</html>

在这里插入图片描述

  • 如果存在父元素, 那么就以父元素为准. 但是需要注意的是, 父元素首先也需要进行定位. 不然该盒子还是以浏览器为准
  • 给父盒子加了定位, 那么子盒子定位就会被限定在父盒子之内.
  • 如果有多级父盒子 , 那么子盒子会一直往上一级一级的找, 如果找到了被定位的父级盒子, 那么就以这个父级盒子为准, 如果一直找到body, 都没有, 那么就以浏览器为标准.
  • 绝对定位是脱离标准流的. 原来的盒子被绝对定位之后, 是不占用原来的标准流的.

子绝父相

子绝父相意思是, 子级使用绝对定位, 父级使用相对定位:

  • 子绝:指的是子元素的position属性设置为absolute(绝对定位)。
  • 父相:指的是父元素的position属性设置为relative(相对定位)或者absolute、fixed等非static值(但在这种场景下,通常指的是relative)。

为什么?

  1. 脱离文档流:当子元素设置为absolute时,它会脱离正常的文档流,这意味着它不会占据空间,不会影响其他元素的布局。也就是说, 子级使用绝对定位是不会影响兄弟或者父级盒子的.
  2. 相对于最近的已定位祖先元素定位:绝对定位的元素会相对于最近的已定位(即position属性值不是static)的祖先元素进行定位。如果没有这样的祖先元素,那么它会相对于初始包含块(通常是视口)进行定位。
  3. 灵活性和控制:通过使父元素为relative,我们可以为子元素的绝对定位提供一个相对稳定的参考点,从而更容易地控制子元素的位置。

例如:

<div class="parent">  <div class="child">  我是子元素  </div>  
</div>
.parent {  position: relative; /* 父元素设置为相对定位 */  width: 300px;  height: 200px;  border: 1px solid black;  
}  .child {  position: absolute; /* 子元素设置为绝对定位 */  top: 50px;  left: 50px;  background-color: lightblue;  
}

固定定位

固定定位是元素固定于浏览器可视区的位置。主要使用场景: 可以在浏览器页面滚动时元素的位置不会改变。就例如我们上面给你看的那个王者荣耀官网的图片一样.
语法:

选择器 {position: fixed;
}

固定定位的特点:

  1. 以浏览器的可视窗口为参照点移动元素
  • 跟父元素没有关系
  • 不会随着滚动条滚动
  • 可是窗口就是浏览器展示页面的窗口.
  1. 固定定位脱离标准流, 不占有原来的位置.

代码案例如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.dh {position: fixed;top: 200px;left: 100px;}body {height: 3000px;}</style>
</head>
<body><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><h3>hello world</h3><div class="dh"><img src="./images/pvp.png" alt=""></div>
</body>
</html>

在这里插入图片描述

边偏移

定位的盒子移动到的最终位置, 有四个属性:

  • top : 顶端偏移量,定义元素相对于其父元素上边线的距离
  • bottom : 底部偏移量,定义元素相对于其父元素下边线的距离
  • left : 左侧偏移量,定义元素相对于其父元素左边线的距离
  • right :右侧偏移量,定义元素相对于其父元素右边线的距离
    在这里插入图片描述

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

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

相关文章

H3C DHCP快速配置指南

1 配置DHCP服务器动态分配IPv4地址 1.1 简介 本案例介绍配置接口工作在DHCP服务器模式&#xff0c;实现动态分配IPv4地址的方法。 1.2 组网需求 如1.2 图1所示&#xff0c;公司将交换机做为核心交换机&#xff0c;现在需要在核心交换机上划分3个VLAN网段&#xff0c;Ho…

数据结构与算法学习笔记三---循环队列的表示和实现(C++)

目录 前言 1.为什么要使用循环队列 2.队列的顺序存储方式的实现 1.定义 2.队列初始化 3.销毁 4.清空队列 5.队列是否为空 6.队列长度 7.队头 8.入队 9.出队 10.遍历队列 11.完整代码 3.参考资料 前言 这篇文章介绍循环队列的表示和用法。 1.为什么要使用循环队…

深入理解Linux下的网络监控工具:iftop

目录标题 1. 什么是iftop?2. 安装iftop在Debian/Ubuntu上安装在CentOS/RHEL上安装在其他Linux发行版上 3. 使用iftop监控网络流量命令行选项界面说明交互命令 4. 相关参数及说明 在维护和监控Linux服务器时&#xff0c;了解网络流量的细节非常重要。网络监控可以帮助我们诊断延…

远程服务器监控工具Navicat Monitor全新发布v3.0 - 支持PostgreSQL用户

Navicat Monitor 是一套安全、简单而且无代理的远程服务器监控工具。它具有强大的功能使你的监控发挥最大效用。受监控的服务器包括 MySQL、MariaDB 和 Percona Server&#xff0c;并与 Amazon RDS、Amazon Aurora、Oracle Cloud、Microsoft Azure 和阿里云等云数据库兼容。Nav…

C# 统计代码运行时长

using System; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Text; using System.Threading; using System.Threading.Tasks; using System.Windows.Forms;namespace Sci {/// <summary>/// 统计代码…

进程间通信:连接不同程序世界的桥梁

目录 一、进程间通信的重要性 二、常见的进程间通信方式 三、进程间通信的目的 四、进程间通信的本质 在计算机编程的领域中&#xff0c;进程间通信&#xff08;Inter-Process Communication&#xff0c;IPC&#xff09;是一个至关重要的概念。当我们在操作系统中运行多个程…

YOLOv5-7.0改进(四)添加EMA注意力机制

前言 关于网络中注意力机制的改进有很多种&#xff0c;本篇内容从EMA注意力机制开始&#xff01; 往期回顾 YOLOv5-7.0改进&#xff08;一&#xff09;MobileNetv3替换主干网络 YOLOv5-7.0改进&#xff08;二&#xff09;BiFPN替换Neck网络 YOLOv5-7.0改进&#xff08;三&…

【智能算法】鹭鹰优化算法(SBOA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献5.代码获取 1.背景 2024年&#xff0c;Y Fu受到自然界中鹭鹰生存行为启发&#xff0c;提出了鹭鹰优化算法&#xff08;Secretary Bird Optimization Algorithm, SBOA&#xff09;。 2.算法原理 2.1算法思想…

【声呐仿真】学习记录2-运行ROV(带camera、sonar、dvl等传感器)例程

【声呐仿真】学习记录2-运行ROV&#xff08;带camera、sonar、dvl等传感器&#xff09;例程 前言第一阶段-学习Gazebo第二阶段-学习URDF、xacro第三阶段-寻找例程跑一个rexrov示例程序1.uuvsimulator quick_start2.能键盘控制的示例程序&#xff08;失败&#xff09;3.能键盘控…

Excel如何设置密码保护【图文详情】

文章目录 前言一、Excel如何设置密码保护&#xff1f;二、Excel如何取消密码保护&#xff1f;总结 前言 在软件项目开发过程中&#xff0c;会输出很多技术文档&#xff0c;其中也包括保密级别很高的服务器账号Excel文档。为了确保服务器账号相关的Excel文档的安全性&#xff0…

CSS 网格布局一行X个排列

<div class"icon-box"><divv-for"(item,index) in icon" :key"index" class"icon"style"cursor: pointer">{{item}}</div></div>.icon-box{display: grid; /**网格布局*/grid-template-columns: r…

NSS题目练习2

[LitCTF 2023]我Flag呢&#xff1f; 打开题目后查看源码即可发现flag [第五空间 2021]WebFTP 看到提示&#xff0c;首先想到用dirsearch扫描链接&#xff0c;看是否存在git泄露 发现存在git泄露&#xff0c;用githack解决 克隆提示目录为空&#xff0c;说明不正确&#xff0c…

容器监控与日志管理

前言&#xff1a;本博客仅作记录学习使用&#xff0c;部分图片出自网络&#xff0c;如有侵犯您的权益&#xff0c;请联系删除 一、Docker监控工具 二、容器日志工具docker logs 三、第三方日志工具 四、容器日志驱动 五、示例 5.1、查看容器中运行的进程的信息 5.2、查看…

液晶显示模块强光实验类目及太阳光模拟器

科技日新月异&#xff0c;液晶显示模块运用得也越来越广泛&#xff0c;用户在购买和使用时&#xff0c;都希望能买到显示效果好&#xff0c;性价比高的产品。本文主要介绍LCM&#xff0f;LED模块在光学方面主要测试项目类别及实验仪器。 测试项目类别 1. 透过率 透过率是指透…

英语学习笔记7——Are you a teacher?

Are you a teacher? 你是教师吗&#xff1f; 词汇 Vocabulary name /neɪm/ n. 名字&#xff0c;名声 英文名字构成&#xff1a; 名 字 姓      given name family name  也叫做&#xff1a;first name last name      例&#xff1a;Yanyan Gao 例句&#xff1…

学习网络安全现在还有前景吗?行业分析报告

如果你现阶段选择入行网络安全&#xff0c;就相当于10年前学IT&#xff0c;当它发展起来的时候&#xff0c;你刚好遇到行业红利期。 网络安全这个职业完全可以改变很多人的人生轨迹。 因为它是个不需要你有多强大的情商&#xff0c;不需要你去学习更多复杂的职场和人际关系技…

halcon获取Licenses--每月一换

转到https://www.51halcon.com/ 点击授权&#xff0c;根据你的版本选择progress或者steady进行下载 记住每月一换哦

2024年小程序视频如何下载到电脑上

随着2024年的到来&#xff0c;将小程序视频无缝下载到电脑上&#xff0c;从此让精彩内容触手可及&#xff0c;不受时间和网络的限制&#xff0c;随时随地启发你的生活和工作。 小程序视频我已经打包好了&#xff0c;有需要的自己下载 小程序视频下载工具打包链接&#xff1a;…

AI数据中心网络技术选型,InfiniBand与RoCE对比分析

InfiniBand与RoCE对比分析&#xff1a;AI数据中心网络选择指南 随着 AI 技术的蓬勃发展&#xff0c;其对数据中心网络的要求也日益严苛。低延迟、高吞吐量的网络对于处理复杂的数据密集型工作负载至关重要。本文分析了 InfiniBand 和 RoCE 两种数据中心网络技术&#xff0c;帮助…

付费文章合集第二期

☞☞付费文章合集第一期 感谢大家一年来的陪伴与支持&#xff01; 对于感兴趣的文章点标题能跳转原文阅读啦~~ 21、Matlab信号处理——基于LSB和DCB音频水印嵌入提取算法 22、CV小目标识别——AITOD数据集&#xff08;已处理&#xff09; 23、Matlab信号发生器——三角波、…