CSS 定位(position) (三)

2024-06-01 11:38
文章标签 css 定位 position frontend

本文主要是介绍CSS 定位(position) (三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

叠放次序(z-index)

当对多个元素同时设置定位时,定位元素之间有可能会发生重叠。在CSS中,要想调整重叠定位元素的堆叠顺序,可以对定位元素应用z-index层叠等级属性,
其取值可为正整数、负整数和0。
比如: z-index: 2;注意:
z-index的默认属性值是0,取值越大,定位元素在层叠元素中越居上。
如果取值相同,则根据书写顺序,后来居上。
后面数字一定不能加单位。
只有相对定位,绝对定位,固定定位有此属性,其余标准流,浮动,静态定位都无此属性,
亦不可指定此属性。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>叠放次序</title><style>div {width: 200px;height: 200px;background-color: pink;position: absolute; /*  绝对定位 */top: 0;left: 0;}div:first-child {z-index: 1; /* font-weight: 700; */}div:nth-child(2) {background-color: purple;top: 30px;left: 30px;z-index: 2;}div:nth-child(3) {background-color: skyblue;top: 60px;left: 60px;}</style>
</head>
<body>
<div></div>
<div></div>
<div></div>
</body>
</html>

在这里插入图片描述

四种定位总结

定位模式是否脱标占有位置是否可以使用边偏移移动位置基准
静态static不脱标,正常模式不可以正常模式
相对定位relative不脱标,占有位置可以相对自身位置移动(自恋型)
绝对定位absolute完全脱标,不占有位置可以相对于定位父级移动位置(拼爹型)
固定定位fixed完全脱标,不占有位置可以相对于浏览器移动位置(认死理型)

定位模式转换

跟 浮动一样, 元素添加了 绝对定位和固定定位之后, 元素模式也会发生转换, 都转换为 行内块模式, 因此 比如 行内元素 如果添加了 绝对定位或者 固定定位后,可以不用转换模式,直接给高度和宽度就可以了。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>定位盒子的模式转换</title><style>div {height: 100px;background-color: pink;/*  float: left;   没有给盒子的宽度 浮动的盒子有模式转换的情况 转换位 行内块 *//* position: fixed;  元素添加了 绝对定位和固定定位之后 元素模式也会发生转换 都转换位 行内块模式 */}span {background-color: purple;width: 100px;height: 100px;/* float: left; 如果盒子本身就需要添加 浮动后者绝对固定定位就需要转换了 */position: absolute;}</style>
</head>
<body><div>定位盒子的模式转换</div><span>行内元素</span>
</body>
</html>

元素的显示与隐藏

在CSS中有三个显示和隐藏的单词比较常见,我们要区分开,他们分别是 display visibility 和 overflow。

他们的主要目的是让一个元素在页面中消失,但是不在文档源码中删除。 最常见的是网站广告,当我们点击类似关闭不见了,但是我们重新刷新页面,它们又会出现和你玩躲猫猫!!

display 显示

display 设置或检索对象是否及如何显示。display : none 隐藏对象 与它相反的是 display:block 除了转换为块级元素之外,
同时还有显示元素的意思。特点: 隐藏之后,不再保留位置。

visibility 可见性

设置或检索是否显示对象。
visible :  对象可视
hidden :  对象隐藏
特点: 隐藏之后,继续保留原有位置。(停职留薪)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>元素的显示和隐藏</title><style>div {width: 100px;height: 100px;background-color: pink;}div:first-child {/* 隐藏元素 不是删除 看不见了而已 但是元素一直存在页面中 但是不保留位置 block 显示 *//* display: none; *//* 隐藏元素 他和display none 最大的区别是 他保留位置 visible 显示 */visibility: hidden;}div:nth-child(2) {background-color: skyblue;}</style>
</head>
<body><div></div><div></div>
</body>
</html>

在这里插入图片描述

鼠标经过显示二维码
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>鼠标经过显示二维码</title><style>div {width: 100px;height: 100px;border-color: pink;text-align: center;line-height: 100px;margin: 100px auto;position: relative; /* 子绝父相 */}div img {position: absolute;left: 100px;top: 0;display: none; /* 隐藏二维码 */}div:hover img {  /* 鼠标经过div的时候 里面那个img 图片会显示出来 */display: block; /* 显示二维码 */}</style>
</head>
<body><div>扫码登录<img src="images/erweima.png" alt=""></div>
</body>
</html>

在这里插入图片描述

overflow 溢出

检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。

visible :  不剪切内容也不添加滚动条。
auto :   超出自动显示滚动条,不超出不显示滚动条
hidden :  不显示超过对象尺寸的内容,超出的部分隐藏掉
scroll :  不管超出内容否,总是显示滚动条
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>overflow属性</title><style>div {width: 100px;height: 200px;border: 1px solid red;/*overflow: visible;  默认的 超出显示 *//*  overflow: auto; 自动 超出就显示滚动条 不超出不显示 *//* overflow: scroll;  一直显示滚动条 */overflow: hidden; /* 溢出隐藏 */}</style>
</head>
<body><div>俄宇航员在国际空间站外面捡垃圾,捞了条漂了10年的毛巾俄宇航员在国际空间站外面捡垃圾,捞了条漂了10年的毛巾俄宇航员在国际空间站外面捡垃圾,捞了条漂了10年的毛巾</div>
</body>
</html>

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

这篇关于CSS 定位(position) (三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1020906

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)