在Css上吃过的亏

news2025/2/23 23:37:43

一、前言

  • 最近参加了公司的一个小程序的开发项目,虽然很简单,但是非常急三天就要交。本来就是实习生加上前端不熟练的我,最终在Css定位上吃了很大的亏。今天就来了解一下Css中的几个定位。

二、什么是定位

  • 在Css中有一个position属性,代表定位,它有四个值,可以通过设置它的TLBR来调整元素位置
    • absolute(绝对)(脱离文档流)
    • relative(相对)(不脱离文档流)
    • fixed(固定)(脱离文档流)
    • sticky(粘性)(不脱离文档流)

三、文档流

  • 想要清楚了解定位,就脱离不开文档流。
    • 字面意思就是元素从上到下,从左到右,该在什么位置就在什么位置。
    • 正常文档流是在我们没有刻意是控制它的时候,每个元素排放在文档都会按顺序排放
    • 脱离文档流就是指它所显示的位置和文档代码就不一定一致了,刻意通过Css控制它来修改它的位置

四、不同定位的作用

1、absolute

  1. 首先第一点,它会脱离文档流,基本上可以理解为,它可以根据给予它的Css来调整自身的位置,而不会根据文档流的顺序来排放
  2. 即便它会脱离文档流,但absolute,定位依据是定位元素的父级,也就是如果它的父级有设置定位,那么它将根据它的父级元素来进行脱离文档流的位置调整
  3. 当它的所有父级元素都没有设置定位时,它将根据body进行定位

2、relative

  1. 不脱离文档流,在文档流本身排放自身元素的位置上,进行Css位置调整

3、fixed

  1. 脱离文档流,不再区分块元素、行内元素、行内块元素,固定定位不占有原来的位置
  2. 固定在浏览器页面上,不随浏览器的滚动而改变位置
  3. 以浏览器为参照物,和父元素没有任何关系

4、sticky

  1. 和fixed一样,以浏览器为参照物
  2. 元素不会脱离文档流,占有原来位置
  3. 粘滞定位可以在元素到达某个位置时,将其固定
  4. 没有达到top值之前正常显示,达到top值之后类似于固定定位,不会跟随滚动条滚动而滚动

五、举例

1、代码

Html页面

<!DOCTYPE html>
<html style="background-color: beige;">
	<head>
		<meta charset="utf-8" />
		<title></title>
		<link rel="stylesheet" type="text/css" href="./css/index.css">
	</head>
	<body>
		<div style="background-color: black; width: 100px; height: 100px;" class="div1"></div>
		
		<div style="background-color: aqua; width: 100px;height: 100px;" class="div2"></div>
		
		<div style="background-color: red; width: 100px;height: 100px;" class="div3"></div>
	</body>
</html>

Css页面

.div1{
	position: relative;
	left: 20px;
	top: 20px;
	
}

.div2{
	position: absolute;
	top: 40px;
	left: 100px;
}

.div3{
	position: relative;
	
}

2、结果图

在这里插入图片描述

3、分析

  1. 黑色为div1,青蓝色为div2,红色为div3
  2. 这里可以看到青蓝色的div定位为absolute,是脱离文档流的,这里因为他的父级都没有,所以直接根据body进行定位
  3. 可以看出absolute和fixed的区别,他们同样脱离文档流,但以下是不同点
    • absolute:根据它的父级元素的定位,但前提是它的父级元素有定位,如果所有父级元素都没有定位,那么将根据body进行定位
    • fixed:以浏览器为参照物,和父元素没有任何关系
  4. relative就是一个很乖的定位,原原本本的按照属于它的位置进行排放,这里可以看出,黑色板块即便设置了设置了偏移量,但下面红色的板块却照常摆放,就是因为两者都为relative,黑色板块只是设置了偏移量,它的本身还是在它原先的位置,因此红色板块才会那样显示

4、补充

为了更好的理解absolute定位,这里增加了一个div,方便理解

<!DOCTYPE html>
<html style="background-color: beige;">
	<head>
		<meta charset="utf-8" />
		<title></title>
		<link rel="stylesheet" type="text/css" href="./css/index.css">
	</head>
	<body>
		<div style="background-color: black; width: 100px; height: 100px;" class="div1"></div>
		
		<div style="background-color: black; width: 500px; height: 500px;" class="div4">
			<div style="background-color: aqua; width: 100px;height: 100px;" class="div2"></div>
		</div>
		
		<div style="background-color: red; width: 100px;height: 100px;" class="div3"></div>
	</body>
</html>
.div1{
	position: relative;
	left: 20px;
	top: 20px;
	
}
.div4{
	position: absolute;
	left: 500px; 
	top: 200px; 
}
.div2{
	position: absolute;
	top: 40px;
	left: 100px;
}
.div3{
	position: relative;
	
}

在这里插入图片描述

说明:

  • 可以看到大的黑色板块和青蓝色板块是脱离文档流的,所以根本不会影响另外两个
  • 而青蓝色是被包含在黑色里的,这里的黑色同样设置了absolute,因此它会在黑色板块里进行原先设置的定位
  • 不管大的黑色设置什么定位属性,青蓝色都会被影响到
  • 如果大的黑色设置的是不脱离文档流的属性,则小的黑色和红色会被影响

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

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

相关文章

技术干货 | ​Navicat 面向 PostgreSQL 查询超时的工具解决方案

早前&#xff0c;我们发表过一篇《PostgreSQL 与 Navicat &#xff1a;数据库的中坚力量》 &#xff0c;从产品的发展介绍了两者的渊源与共性&#xff0c;获得了许多童鞋的认可。而随着PostgreSQL 在国内热度愈发高涨&#xff0c;应用也愈发广泛。近期&#xff0c;我们收到许多…

Chirpstack服务器简介和搭建教程

LoRaWAN网络主要优势体现在低成本、广域连接和低功耗&#xff0c;同时具有较多的开源平台可供使用。使用Chirpstack服务器可以快速搭建本地LoRaWAN网络。本文重点介绍一下Chirpstack服务器是做什么的和Chirpstack服务器的安装教程&#xff1a; Chirpstack是一款多组件的、部署…

vue中 antdesginVue <a-image/>图片标签去掉蒙层(鼠标滑过)里面的“预览”二字 或者使用deep自定义样式不生效问题。

vue中 antdesginVue 图片标签去掉蒙层&#xff08;鼠标滑过&#xff09;里面的“预览”二字 或者使用deep自定义样式不生效问题。 看似去掉这两个字很简单&#xff0c; 其实搞了我一上午&#xff0c;是真的不好去掉呀&#xff0c;这里得吐槽下ant官方 。。。。什么deep呀都是不…

是面试官放水,还是公司实在是太缺人?这都没挂,字节跳动原来这么容易进...

字节是大企业&#xff0c;是不是很难进去啊&#xff1f;” “在字节跳动做软件测试&#xff0c;能得到很好的发展吗&#xff1f; 一进去就有12K&#xff0c;其实也没有想的那么难” 直到现在&#xff0c;心情都还是无比激动&#xff01; 本人211非科班&#xff0c;之前在华为和…

PostgreSQL 16 beta 重磅发布,OpenPie 再次引领中国贡献关键力量

PostgreSQL 一直被誉为全球最先进的开源关系数据库之一&#xff0c;在 DB-engines 排行榜上长期稳居前五。5 月 25 日&#xff0c;PostgreSQL 全球开发团队官方宣布&#xff0c;PostgreSQL 16 Beta 1 版本正式发布。 本次 PostgreSQL 新版本功能亮点众多&#xff0c;涉及多个模…

Docker环境java程序的时间设置

先上解决方案 java程序生成的时间、日志时间不对的解决方案&#xff1a; #在Dockerfile文件中加入以下两行代码&#xff0c;用于指定bild的镜像为东八区 ENV TZAsia/Shanghai RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezoneDoc…

生产检验配置和操作

1、概念 在SAP系统的生产过程中运行中间产品或成品的质量流程&#xff0c;例如每个班次的检查等&#xff0c;在生产订单发布时生成检验批&#xff0c;在系统中进行检验的检验类型为03&#xff0c;当有生产订单发布时&#xff0c;将在系统中自动创建检验批。 2、前台和后台配置…

【操作系统】03.内存管理

存储器的层级结构 程序的运行 现代操作系统使用的连接方式&#xff1a;运行时动态链接 对某些模块的链接推迟到程序执行时才进行 现代操作系统使用的装入方式&#xff1a;动态重定位 程序装入内存后&#xff0c;逻辑地址不会立即转换成物理地址&#xff0c;而是推迟到指令执行…

Energy-Based Learning for Scene Graph Generation

[2103.02221] Energy-Based Learning for Scene Graph Generation (arxiv.org) 目录 Abstarct 1 Introduction 2 Approach 2.1 Scene Graph Generation 2.2 Energy Based Modeling 2.3 Energy Models for Scene Graphs Generation 2.4 Energy Model Architectue 2.4.1…

PCB多层板为什么都是偶数层?奇数层不行吗?

PCB板有单面、双面和多层的&#xff0c;其中多层板的层数不限&#xff0c;目前已经有超过100层的PCB&#xff0c;而常见的多层PCB是四层和六层板。那为何大家会有“PCB多层板为什么都是偶数层&#xff1f;”这种疑问呢&#xff1f;相对来说&#xff0c;偶数层的PCB确实要多于奇…

朋友面试字节要求月薪25K,明显感觉他背了很多面试题...

最近有朋友去字节面试&#xff0c;面试前后进行了20天左右&#xff0c;包含4轮电话面试、1轮笔试、1轮主管视频面试、1轮hr视频面试。 据他所说&#xff0c;80%的人都会栽在第一轮面试&#xff0c;要不是他面试前做足准备&#xff0c;估计都坚持不完后面几轮面试。 其实&#…

Unity WebGL打包配置本地服务器

第一步打包 1&#xff09;、先对Player Setting进行设置 2&#xff09;、设置打包的窗口大小 3&#xff09;、遇到异常以及压缩格式 第一个启用异常&#xff0c;指用户指定在运行时意外的代码行为&#xff08;通常被认为错误&#xff09;如何被处理&#xff0c;有三个选项…

进程(四)

进程四 2.21 管程2.22 死锁的概念2.23 死锁的处理策略2.23.1 破坏四个条件2.23.2 动态策略: 避免死锁2.23.3 死锁的检测和解除 2.21 管程 本小计知识概览 为什么要引入管程 管程的定义和基本特征 管程是一种特殊的软件模块&#xff0c;有这些部分组成: 局部于管程的共享数据结…

javaWeb ssh微博系统myeclipse开发mysql数据库MVC模式java编程计算机网页设计

一、源码特点 java ssh微博系统是一套完善的web设计系统&#xff08;系统采用ssh框架进行设计开发&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开 发。开发环境为TOMCAT7.0,Myecli…

智慧校园建设主要包括哪些方面的内容?

在当今数字化的时代&#xff0c;越来越多的学校开始实施智慧校园计划&#xff0c;旨在为学生和教师提供更加高效、便捷的学习和教学环境。 那么&#xff0c;究竟什么是智慧校园呢&#xff1f;智慧校园建设主要包括哪些方面的内容&#xff1f;这篇就来详细讲一讲&#xff01; …

3年外包出来,华为、字节全都一面挂,我哭死.....

测试员可以先在外包积累经验&#xff0c;以后去大厂就很容易&#xff0c;基本不会被卡&#xff0c;事实果真如此吗&#xff1f;但是在我身上却是给了我很大一巴掌... 所谓今年今天履历只是不卡简历而已&#xff0c;如果面试答得稀烂&#xff0c;人家根本不会要你。况且要不是大…

字节软测划水四年,内容过于真实......

先简单交代一下吧&#xff0c;潇潇是某不知名211的本硕&#xff0c;18年毕业加入一个小厂&#xff0c;之后跳槽到了字节跳动&#xff0c;一直从事测试开发相关的工作。之前没有实习经历&#xff0c;算是四年半的工作经验吧。 这四年半之间他完成了一次晋升&#xff0c;换了一家…

(转载)基于多层编码遗传算法的车间调度算法(matlab实现)

以下内容大部分来源于《MATLAB智能算法30个案例分析》&#xff0c;仅为学习交流所用。 1 理论基础 遗传算法具有较强的问题求解能力&#xff0c;能够解决非线性优化问题。遗传算法中的每个染色体表示问题中的一个潜在最优解&#xff0c;对于简单的问题来说&#xff0c;染色体…

【ProtoBuf】2.环境配置

————————————每一个不曾起舞的日子都是对生命的辜负。 ProtoBuf安装 一. 安装Protofbuf-Win二. 配置环境变量三.验证是否添加成功四. Linux下Protobuf安装包的安装1. 下载ProtoBuf2. 解压压缩包3. 安装ProtoBuf4. 最后添加内容5.检查是否安装成功 五. 升级g到8版本…

Java 高级应用-多线程-(一)实现 Runnable 接口与继承 Thread 类

1.1 程序、进程与线程 • 程序&#xff08;program&#xff09;&#xff1a;为完成特定任务&#xff0c;用某种语言编写的一组指令的集合。即指一段 静态的代码&#xff0c;静态对象。 • 进程&#xff08;process&#xff09;&#xff1a;程序的一次执行过程&#xff0c;或是正…