CSS - 浮动、定位

浮动

CSS浮动(Float)是一种布局技术,用于控制元素在页面中的位置。通过将元素浮动到其容器的左侧或右侧,可以使其他元素环绕在其周围。

相关属性:

  • float:用于设置元素的浮动方向。可以设置为left(左浮动)或right(右浮动)。

  • clear:用于控制元素周围的浮动元素对其的影响。可以设置为left(清除左浮动)、right(清除右浮动)、both(清除左右浮动)或none(不清除浮动)。

  • clearfix:当父元素包含浮动元素时,可以使用clearfix技术来清除浮动。这可以通过在父元素上应用clearfix类来实现,例如:

.clearfix::after {
    content: "";
    display: table;
    clear: both;
}

注意:

  • 浮动元素会脱离正常的文档流,其他元素会环绕在其周围。
  • 浮动元素的宽度默认会根据其内容自动调整,除非显式设置了宽度。
  • 浮动元素会影响其容器的高度计算,容器可能会塌陷(高度为0)。
  • 浮动元素之间可能会发生重叠,需要适当处理。
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>浮动学习</title>

    <style>
        div {
            width: 100px;
            height: 100px;
            background-color: red;
            float: left;
        }
    </style>


</head>

<body>

    <div></div>
    <div></div>
    <div></div>
</body>

</html>

在这里插入图片描述

既然我们可以定义浮动位置,那么我们也可以清除浮动
清除浮动是为了解决浮动元素对其容器造成的高度塌陷和布局问题。以下是一些常用的清除浮动的方法:

  • 使用clear属性:在浮动元素的容器中添加一个空的块级元素,并为其应用clear: both;样式。这会使该元素出现在浮动元素的下方,从而清除浮动。例如:
<div class="clearfix">
    <div class="float-left">浮动元素1</div>
    <div class="float-left">浮动元素2</div>
    <div class="clear"></div>
</div>
.clearfix::after {
    content: "";
    display: table;
    clear: both;
}
  • 使用overflow属性:在浮动元素的容器上应用overflow: hidden;或overflow: auto;样式。这会创建一个新的块级格式化上下文(BFC),从而清除浮动。例如:
.container {
    overflow: hidden;
}
  • 使用伪元素:在浮动元素的容器中使用伪元素来清除浮动。这是一种常见的clearfix技术。例如:
.clearfix::after {
    content: "";
    display: table;
    clear: both;
}

示例

<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>清除浮动</title>

    <style>
        .box {
            background-color: violet;
            /* overflow清除浮动 */
            overflow: hidden;
        }
        /* 伪元素清除浮动     */
        /* .box::after {
            clear: both;
            content: '';
            display: block;
            visibility: hidden;
        } */
        
        .box>div {
            width: 200px;
            height: 100px;
            float: left;
            background-color: black;
        }
    </style>

</head>

<body>


    <div class="box">
        <div></div>
        <!-- <div></div>
        <div></div>
        <div></div>
        <div></div>
        <div></div>
        <div></div> -->
    </div>


    <!-- <div style="width: 1000px;height: 100px;background-color: blue;"></div> -->
</body>

</html>

在这里插入图片描述

定位

CSS定位是一种用于控制元素在页面中精确位置的技术。CSS提供了多种定位属性,包括相对定位(relative)、绝对定位(absolute)、固定定位(fixed)和粘性定位(sticky)

  • 相对定位(relative):通过设置position: relative;可以将元素相对于其正常位置进行偏移。使用top、right、bottom和left属性可以控制元素相对于其原始位置的偏移量。

  • 绝对定位(absolute):通过设置position: absolute;可以将元素相对于其最近的已定位祖先元素进行定位。如果没有已定位的祖先元素,则相对于文档的初始包含块进行定位。使用top、right、bottom和left属性可以控制元素相对于其定位参考点的偏移量。

  • 固定定位(fixed):通过设置position: fixed;可以将元素相对于视口进行定位,即无论页面滚动与否,元素都会保持在固定位置。使用top、right、bottom和left属性可以控制元素相对于视口的偏移量。

  • 粘性定位(sticky):通过设置position: sticky;可以将元素在滚动到特定位置时固定在屏幕上。使用top、right、bottom和left属性可以控制元素相对于其父元素或视口的偏移量。

<!-- <!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>绝对定位</title>
    <style>
        /* 在没有父元素或者父元素没有定位的情况下 以浏览器为标准定位 
            关键字:absolute 
        */
        
        * {
            margin: 0;
            padding: 0;
        }
        
        .father {
            width: 500px;
            height: 500px;
            background-color: pink;
            position: absolute;
        }
        
        .son {
            position: absolute;
            width: 100px;
            top: 100px;
            right: 10px;
            height: 100px;
            background-color: blue;
        }
    </style>
</head>

<body>

    <div class="father">
        <div class="son">


        </div>

    </div>

</body>

</html> -->

<!DOCTYPE html>
<html>
<head>
    <title>CSS定位示例</title>
    <style>
        .relative {
            position: relative;
            top: 20px;
            left: 20px;
            background-color: yellow;
        }

        .absolute {
            position: absolute;
            top: 50px;
            right: 50px;
            background-color: red;
        }

        .fixed {
            position: fixed;
            bottom: 20px;
            right: 20px;
            background-color: blue;
        }

        .sticky {
            position: sticky;
            top: 100px;
            background-color: green;
        }

        .container {
            height: 2000px;
        }
    </style>
</head>
<body>
    <div class="container">
        <div class="relative">相对定位</div>
        <div class="absolute">绝对定位</div>
        <div class="fixed">固定定位</div>
        <div class="sticky">粘性定位</div>
    </div>
</body>
</html>

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

刷题之动态规划-子序列

前言 大家好&#xff0c;我是jiantaoyab&#xff0c;开始刷动态规划的子序列类型相关的题目&#xff0c;子序列元素的相对位置和原序列的相对位置是一样的 动态规划5个步骤 状态表示 &#xff1a;dp数组中每一个下标对应值的含义是什么>dp[i]表示什么状态转移方程&#xf…

[工具使用]绕过付费-适用于谷歌/火狐/Edge浏览器

绕过付费-适用于谷歌/火狐/Edge浏览器 bypass-paywalls是一款浏览器插件&#xff0c;可以帮助绕过选定网站的付费 链接&#xff1a;https://github.com/iamadamdev/bypass-paywalls-chrome 一、谷歌/Edge浏览器安装说明&#xff08;支持自定义网站&#xff09; 1、从Github下…

Xinstall助力提升用户体验:一键打开App用户页面

在移动互联网时代&#xff0c;App已经成为我们日常生活中不可或缺的一部分。然而&#xff0c;随着App数量的激增&#xff0c;如何让用户更便捷地打开和使用App&#xff0c;提升用户体验&#xff0c;成为了开发者和广告主们亟待解决的问题。此时&#xff0c;Xinstall作为国内专业…

golang使用sse事件流调用AI大模型

目录 前言第一步 解决没有官方SDK的痛第二步 实现流式传输什么是SSE,SSE和WebSocket的区别基于gin实现SSE服务器gin接收AI大模型数据流响应1. 前端携带自定义问题请求后端接口2. 后端接受请求解析问题&#xff0c;然后创建stream对象3. 构建请求参数&#xff0c;调用创建数据流…

《CSS 知识点》仅在文本有省略号时添加 tip 信息

html <div ref"btns" class"btns"><div class"btn" >这是一段很短的文本.</div><div class"btn" >这是一段很短的文本.</div><div class"btn" >这是一段很长的文本.有省略号和tip.<…

ubuntu或类Debian获取某些包的离线版本-包括依赖(还有一些意想不到的用途,哈哈)

前言 偶尔能碰到很特殊的情况。网址白名单&#xff0c;纯内网&#xff0c;超多依赖及一些很难描述的场景。 比如一些少见的发行版缺少某些包。这时候可以找一台类似的系统环境来下载离线包及 其依赖包&#xff0c;然后转移到内网进行安装。如果是网址白名单&#xff0c;或者纯内…

AI的力量感受(附网址)

输入 科技感的 二维码&#xff0c;生成如下&#xff0c;还是可以的 输入金属感 的芯片&#xff0c;效果就很好了 金属感 打印机&#xff0c;细节丰富&#xff0c;丁达尔效应 就有点跑题了 金属感 扫码仪 还有点像 3D 封装长这样&#xff0c;跑题比较严重 总之&#xff0c;AI还…

yolov8安全帽检测项目开发(python开发,带有训练模型,可以重新训练,并有Pyqt5界面可视化)

不需要程序&#xff0c;只需要数据集的&#xff0c;想自己搭建模型训练的&#xff0c;可以免费下载&#xff08;积分已经设置为0&#xff09;&#xff1a;https://download.csdn.net/download/qq_40840797/89100918 1.项目介绍&#xff1a;&#xff08;视频运行链接&#xff1…

KMP刷leetcode速通

前言 KMP真厉害&#xff0c;刷题刷到 28.找出字符串中第一个匹配项的下标 和 1668.最大重复子字符串 next 数组用来匹配不上时&#xff0c;前缀 j j j 可以快速回退到 n e x t [ j − 1 ] next[j-1] next[j−1] 的位置。 void getNext(vector<int>& next, const…

我院组织《医务人员如何构建良好人际关系》主题讲座

为进一步规范医务人员行为&#xff0c;熟练运用沟通技巧&#xff0c;掌握沟通技能&#xff0c;更好的为患者服务&#xff0c;提高工作效率。3月7日&#xff0c;北京精诚博爱医院护理部特别邀请了原海军总医院心理科郭勇教授&#xff0c;为临床医务工作者作了《心理健康教育之医…

文本溢出隐藏用小点表示(多行溢出,单行溢出)

一、效果 文本溢出隐藏&#xff0c;用小点表示。 单行溢出隐藏&#xff1a; 规定第几行溢出隐藏&#xff1a; 二、代码 单行&#xff1a; <p class"p1">gdgFIAHfuiasdhgiubvsDIUGHSFUIGHGDFUIGUISDFHVUIJKDFDFUIKGJKGJKG</p> width: 200px; height:…

Docker 安装RabbitMQ以及使用客户端图形化界面

目录 一、点击进入docker 镜像仓库 1.1 直接在官网里 搜索 rabbitmq 1.2 在标签里 直接搜索3.10-management 因为这个标签包含用户操作界面 二、启动docker 2.1 首先拉取镜像&#xff1a; 2.2 Docker运行&#xff0c;并设置开机自启动 三、访问用户操作界面 一、点击进入…

项目经理要懂技术吗?

项目经理就好比乐团的指挥&#xff0c;指挥可能不需要精通每种乐器&#xff0c;但是指挥应该具备相应的音乐知识&#xff0c;对每种乐器有着自己的理解和经验&#xff0c;并且能够与乐队每个人进行专业上的沟通。而项目的专业性越强&#xff0c;对于项目经理的技术水平要求就越…

码住财务记账软件大揭秘!财务记账软件推荐指南

财务管理软件在现代企业管理中发挥着至关重要的作用。本篇文章将为大家介绍10款财务管理软件&#xff1a;Zoho Books、畅捷通T、速达财务软件、金税管家、QuickFile、Kashoo、AccountingSuite、Manager、金蝶KIS、Oracle NetSuite。 一、Zoho Books Zoho Books以其强大的功能…

Git-LFS 远程命令执行漏洞 CVE-2020-27955 漏洞复现

今天遇到了一个比较有意思的洞&#xff0c;复现一下下.......... 漏洞描述 Git LFS 是 Github 开发的一个 Git 的扩展&#xff0c;用于实现 Git 对大文件的支持 一些受影响的产品包括Git&#xff0c;GitHub CLI&#xff0c;GitHub Desktop&#xff0c;Visual Studio&#xff0…

Shoplazza闪耀Shoptalk 2024,新零售创新解决方案引领行业新篇章!

在近期举办的全球零售业瞩目盛事——Shoptalk 2024大会上,全球*的零售技术平台-店匠科技(Shoplazza)以其*的创新实力与前瞻的技术理念,成功吸引了与会者的广泛关注。此次盛会于3月17日至20日在拉斯维加斯曼德勒湾隆重举行,汇聚了逾万名行业精英。在这场零售业的盛大聚会上,Shop…

每日一题 第八十二期 CodeTON Round 8 (Div. 1 + Div. 2, Rated, Prizes!)

C1. Bessie’s Birthday Cake (Easy Version) time limit per test: 2 seconds memory limit per test: 256 megabytes input: standard input output: standard output Proof Geometric Construction Can Solve All Love Affairs - manbo-p ⠀ This is the easy versio…

深度学习理论基础(四)Parser命令行参数模块

学习目录&#xff1a; 深度学习理论基础&#xff08;一&#xff09;Python及Torch基础篇 深度学习理论基础&#xff08;二&#xff09;深度神经网络DNN 深度学习理论基础&#xff08;三&#xff09;封装数据集及手写数字识别 深度学习理论基础&#xff08;四&#xff09;Parse…

【深入理解Java IO流0x05】Java缓冲流:为提高IO效率而生

1. 引言 我们都知道&#xff0c;内存与硬盘的交互是比较耗时的&#xff0c;因此适当得减少IO的操作次数&#xff0c;能提升整体的效率。 Java 的缓冲流是对字节流和字符流的一种封装&#xff08;装饰器模式&#xff0c;关于IO流中的一些设计模式&#xff0c;后续会再出博客来讲…

(css)el-tag标签,el-select多选框,el-cascader级联选框自定义样式

(css)el-tag标签&#xff0c;el-select多选框&#xff0c;el-cascader级联选框自定义样式 css: :root {--button-color: #065de0; }// 标签 .tagNew {margin-right: 20px;border-radius: 20px; }.el-tag.el-tag--info {background-color: var(--button-color);border-color: v…