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

相关文章

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

vue+el国际化-东抄西鉴组合拳

vue-i18n 国际化参考 https://blog.csdn.net/zuorishu/article/details/81708585 说得比较详细。 另外做点补充,比如这里cn下的可以以项目模块加公共模块来细分。 import zhLocale from 'element-ui/lib/locale/lang/zh-CN' //引入element语言包const cn = {mess

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

background-position切图

老生常谈,网上也很多,但是还是记下。 .overview-user-icon {background-image: url('../../../../static/imgs/overview-201811161524.svg');width: 24px;height: 24px;display: inline-block;background-size: 475% 458.3333333333

vue+elementUI下拉框联动显示

<el-row><el-col :span="12"><el-form-item label="主账号:" prop="partyAccountId" :rules="[ { required: true, message: '主账号不能为空'}]"><el-select v-model="detailForm.partyAccountId" filterable placeholder="

vue+elementui分页输入框回车与页面中@keyup.enter事件冲突解决

解决这个问题的思路只要判断事件源是哪个就好。el分页的回车触发事件是在按下时,抬起并不会再触发。而keyup.enter事件是在抬起时触发。 so,找不到分页的回车事件那就拿keyup.enter事件搞事情。只要判断这个抬起事件的$event中的锚点样式判断不等于分页特有的样式就可以了 @keyup.enter="allKeyup($event)" //页面上的//js中allKeyup(e