【Web前端开发基础】CSS的结构伪类选择器、伪元素、浮动

news2024/11/15 17:39:11

CSS的浮动

目录

  • CSS的浮动
    • 一、学习目标
    • 二、文章内容
      • 2.1 结构伪类选择器
      • 2.2 伪元素
      • 2.3 标准流
      • 2.4 浮动
      • 2.5 清除浮动
      • 2.6 拓展(BFC)
    • 三、综合案例
      • 3.1 小米模块案例
      • 3.2 网页导航案例

一、学习目标

  1. 能够使用结构伪类选择器在HTML中选元素
  2. 能够说出标准流元素的布局特点
  3. 能够说出浮动元素的特点
  4. 能够使用浮动完成小米模块布布局案例
  5. 能够说出清除浮动的目的,并能够使用清除浮动的方法

二、文章内容

2.1 结构伪类选择器

目标:能够使用结构伪类选择器在HTML中定位元素

  1. 作用与优势:
    • 作用:根据元素在HTML中的结构关系查找元素
    • 优势:减少对于HTML中类的依赖,有利于保持代码整洁
    • 场景:常用于查找某父级选择器中的子元素
  2. 选择器:
    在这里插入图片描述
    n的注意点:
    • n为0、1、2、3、4、5、6、……
    • 通过n可以组成常见公式(如果是n公式,则n从0开始计算)
      在这里插入图片描述
  3. 结构伪类选择器易错点
    问题:在下列案例中,如果需要找到第一个a标签,如何去查找?
    在这里插入图片描述
    ul>li*8>a{我是第$个a标签} 中,如果需要找到第一个a标签,结构伪类选择器注意不要写错
    错误: ul li a:first-child { css } 这样的写法会把所有的a标签都选择中
    正确:ul li:first-child a { css } 这样只会选中第一个a标签

在这里插入图片描述
E:nth-child(n) { css } 的注意事项

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        /* 需求:使用 nth-child() 给第一个 span 标签添加样式 */
        /* div span:nth-child(1) {这个是选不到第一个 span 标签的
        color: pink;
        } */

        div span:nth-child(2) {
            color: red;
        }

        /* 总结:nth-child(n) 选择的是父元素里面的第 n 个孩子,它不管里面的孩子是否是同一种类型 */
    </style>
</head>
<body>
    <div>
        <p>段落标签</p>
        <span>span标签1</span>
        <span>span标签2</span>
        <span>span标签3</span>
    </div>
</body>
</html>

上面的问题可以使用 E:first-of-type { css } E:last-of-type { css }
E:nth-of-type(n) { css } E:nth-last-of-type(n) { css }来解决

  • 结构伪类选择器就是选择第n个元素
  • nth-child 是从所有子级开始算的,可能是不同类型
  • nth-of-type 是指同一种类型的子级,比如 ul li:nth-of-type(2) 就是选择第二个li
  • 关于 nth-child(n) 我们要知道 n 是从0开始算的,要记住常用的公式
  • 如果是无序列表,我们肯定使用nth-child更多

2.2 伪元素

目标:能够使用伪元素在网页中创建内容

  • 伪元素:一般页面中的非主体内容可以使用伪元素

  • 区别

    1. 元素:HTML设置的标签
    2. 伪元素:由CSS模拟出来的标签效果
  • 种类
    在这里插入图片描述
    在这里插入图片描述

  • 注意点

    1. 有一个必加的属性 content: ‘伪元素的内容’;
    2. before在内容的前面,after在内容的后面
    3. before和after创建一个元素,但是属于行内元素
    4. 因为在DOM里面看不见刚才创建的元素,所以我们称为伪元素
    5. 伪元素标签选择器一样,权重为1

2.3 标准流

目标:能够认识标准流的默认排布方式及其特点

  • 标准流:又称文档流,是浏览器在渲染显示网页内容时默认采用的一套排版规则,规定了应该以何种方式排列元素
  • 常见标准流排版规则:
    1. 块级元素:从上往下,垂直布局,独占一行
    2. 行内元素 或 行内块元素:从左往右,水平布局,一行可以显示多个,空间不够自动折行

2.4 浮动

目标:能够认识使用浮动的作用,了解浮动的特点

  1. 浮动的作用
    • 早期的作用:图文环绕
      在这里插入图片描述
    • 现在的作用:网页布局
      场景:让垂直布局的盒子变成水平布局,如:一个在左,一个在右
      在这里插入图片描述
  2. 浮动的代码
    • 属性名:float
    • 属性值:
      在这里插入图片描述
  3. 浮动的特点
    • 浮动的元素会脱离标准流(简称:脱标),相当于漂浮到了空中,在标准流中不占位置
    • 浮动的元素层级比标准流高出了半个级别,可以覆盖标准流中的元素
    • 浮动找浮动,下一个浮动元素会在上一个浮动元素后面左右浮动
    • 浮动会受到上面元素边界的影响
    • 浮动元素有特殊的显示效果:①一行可以显示多个 ②可以以设置宽高
    • 浮动的元素不能通过text-align:center或者margin:0 auto,让浮动元素本身水平居中
  4. 浮动的案例
    • (案列)网页布局案例
      需求:使用浮动,完成设计图中布局效果
      在这里插入图片描述
    • (案例)小米模块案例
      需求:使用浮动,完成设计图中布局效果
      在这里插入图片描述
    • (案例)网页导航案例
      需求:使用浮动,完成设计图中布局效果
      在这里插入图片描述
  5. 书写网页导航步骤:
    (1) 清除默认的margin和padding
    (2) 找到ul,去除小圆点
    (3) 找到li标签,设置浮动让li一行中显示
    (4) 找到a标签,设置宽高 → a标签默认是行内元素,默认不能设置宽高??
    • 方法一:给a标签设置 display : inline-block
    • 方法二:给a标签设置 display : block
    • 方法三:给a设置 float : left

2.5 清除浮动

目标:能够认识清除浮动的目的,并且能够使用清除浮动的方法

  1. 清除浮动的介绍

    • 含义:清除浮动带来的影响
      • 影响:如果子元素浮动,此时子元素不能撑开标准流的块级父元素
    • 原因:子元素浮动后脱标 → 不占位置
    • 目的:需要父元素有高度,从而不影响其他网页元素的布局
  2. 清除浮动的方法
    清除浮动的方法 — ① 直接设置父元素高度

    • 优点:简单粗暴,方便
    • 缺点:有些布局中不能固定父元素高度。如:新闻列表、京东推荐模块
      在这里插入图片描述

    清除浮动的方法 — ② 额外标签法

    • 操作:
      • 在父元素的最后添加一个块级元素
      • 需要给添加的块级元素设置清除浮动的核心代码:clear: both;
      • 缺点:会在页面中添加额外的标签,会让页面的HTML结构变得复杂

    清除浮动的方法 — ③ 单伪元素清除法

    • 操作:用伪元素替代了额外标签
      /* ① :基本写法 */
      .clearfix::after {
        content: "";
        display: block;
        clear: both;
      }
      /* ② :补充写法 */
      .clearfix::after {
        content: "";
        display: block;
        clear: both;
        /* 补充代码:在网页中看不到伪元素 */
        height: 0;
        visibility: hidden;
      }
      
    • 优点:项目中使用,直接给标签加类即可清除浮动

    清除浮动的方法 — ④ 双伪元素清除法

    • 作用:①清除浮动 ②解决外边距折叠的塌陷现象

    • 操作:

      .clearfix::before,
      .clearfix::after {
        content: "";
        display: table;
      }
      .clearfix::after {
        clear: both;
      }
      
    • 优点:项目中使用,直接给标签加类即可清除浮动

    清除浮动的方法 — ⑤ 给父元素设置overflow : hidden

    • 操作:直接给父元素设置一个overflow: hidden;
    • 优点:方便

2.6 拓展(BFC)

  • 块格式化上下文(Block Formatting Context):BFC
    • 是Web页面的可视CSS渲染的一部分,是块盒子的布局过程中发生的区域,也是浮动元素与其他元素交互的区域
  • 创建BFC方式
    1. html标签是BFC盒子
    2. 浮动元素是BFC盒子
    3. 行内块元素是BFC盒子
    4. overflow属性取值不为visible。如:auto、hidden…
    5. ……
  • BFC盒子常见特点:
    1. BFC盒子会默认包裹住内部子元素(标准流、浮动)→ 应用:清除浮动
    2. BFC盒子本身与子元素之间不存在margin的塌陷现象 → 应用:解决margin的塌
    3. ……

三、综合案例

3.1 小米模块案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        /* 去除掉标签默认的margin和padding */
        * {
            margin: 0;
            padding: 0;
        }

        .box {
            width: 1226px;
            height: 614px;
            /* background-color: pink; */
            margin: 100px auto;
        }

        .left {
            float: left;
            width: 234px;
            height: 614px;
            background-color: #800080;
        }

        .right {
            float: right;
            width: 978px;
            height: 614px;
            /* background-color: yellow; */
        }

        .item {
            float: left;
            width: 234px;
            height: 300px;
            background-color: #87ceeb;
            margin-right: 14px;
            margin-bottom: 14px;
        }

        /* 找到的是 第 4 和第 8个 4倍数 4n */
        .item:nth-child(4n) {
            /* background-color: red; */
            margin-right: 0;
        }

        /* 找到从第5个开始往后的所有个子元素 */
        .item:nth-child(n+5) {
            margin-bottom: 0;
        }
    </style>
</head>
<body>
    <!-- 布局流程:从上往下,从外往内 -->
    <div class="box">
        <div class="left"></div>
        <div class="right">
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
            <div class="item"></div>
        </div>
    </div>
</body>
</html>

在这里插入图片描述

3.2 网页导航案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        /* 1、去除标签默认的margin和padding */
        * {
            margin: 0;
            padding: 0;
        }

        /* 2、找到ul,去除小圆点 */
        ul {
            list-style: none;
        }

        /* 3、找到li标签,设置浮动 */
        ul li {
            float: left;
        }

        /* 4、找到a标签,设置宽高 */
        ul li a {
            /* a标签默认是行内元素,不能直接设置宽高 */
            /* 1、转换成行内块元素 */
            /* display: inline-block; */
            /* 2、转换成块级元素 */
            /* display: block; */
            /* 3、设置浮动 */
            float: left;
            width: 80px;
            height: 50px;
            background-color: #ffc0cb;
            text-decoration: none;
            text-align: center;
            line-height: 50px;
            color: #fff;
            font-size: 16px;
        }

        ul li a:hover {
            background-color: #008000;
        }
    </style>
</head>
<body>
    <ul>
        <li><a href="#">新闻1</a></li>
        <li><a href="#">新闻2</a></li>
        <li><a href="#">新闻3</a></li>
        <li><a href="#">新闻4</a></li>
        <li><a href="#">新闻5</a></li>
        <li><a href="#">新闻6</a></li>
        <li><a href="#">新闻7</a></li>
        <li><a href="#">新闻8</a></li>
    </ul>
</body>
</html>

在这里插入图片描述

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

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

相关文章

Kafka 问题排查

订单宽表数据不同步 事情的起因是专员在 ze app 上查不到订单了&#xff0c;而订单数据是从 mysql 的 order_search_info 查询的&#xff0c;order_search_info 表的数据是从 oracel 的 BZ_ORDER_INFO 表同步过来的&#xff0c;查不到说明同步有问题 首先重启&#xff0c;同步…

《WebKit 技术内幕》学习之五(2): HTML解释器和DOM 模型

2.HTML 解释器 2.1 解释过程 HTML 解释器的工作就是将网络或者本地磁盘获取的 HTML 网页和资源从字节流解释成 DOM 树结构。 这一过程中&#xff0c;WebKit 内部对网页内容在各个阶段的结构表示。 WebKit 中这一过程如下&#xff1a;首先是字节流&#xff0c;经过解码之…

终端(命令提示符或Windows PowerShell或Azure Cloud Shell)概述

终端&#xff08;命令提示符或Windows PowerShell或Azure Cloud Shell&#xff09;是一种很 不 好用的东西 就是要背&#xff0c;很 不 爽 介绍 Windows 终端是一个新式主机应用程序&#xff0c;它面向你喜爱的命令行 shell&#xff0c;如命令提示符、PowerShell 和 bash&…

力扣刷MySQL-第五弹(详细讲解)

&#x1f389;欢迎您来到我的MySQL基础复习专栏 ☆* o(≧▽≦)o *☆哈喽~我是小小恶斯法克&#x1f379; ✨博客主页&#xff1a;小小恶斯法克的博客 &#x1f388;该系列文章专栏&#xff1a;力扣刷题讲解-MySQL &#x1f379;文章作者技术和水平很有限&#xff0c;如果文中出…

Python 算法交易实验67 第一次迭代总结

说明 在这里对第一次迭代&#xff08;2023.7~ 2024.1&#xff09;进行一些回顾和总结&#xff1a; 回顾&#xff1a; 1 实现了0~1的变化2 在信息隔绝的条件下&#xff0c;无控制的操作&#xff0c;导致被套 总结&#xff1a; 思路可行&#xff0c;在春暖花开的时候&#x…

设备对象(DEVICE_OBJECT)

设备对象(DEVICE_OBJECT) 每个驱动程序会创建一个或多个设备对象&#xff0c;用DEVICE_OBJECT数据结构表示。每个设备对象都会有一个指针指向下一个设备对象&#xff0c;因此就形成一个设备链。设备对象链的第一个设备是由DRIVER_OBJECT结构体中指明的。设备对象保存设…

C++ 之LeetCode刷题记录(十五)

&#x1f604;&#x1f60a;&#x1f606;&#x1f603;&#x1f604;&#x1f60a;&#x1f606;&#x1f603; 开始cpp刷题之旅。 依旧是追求耗时0s的一天。 94. 二叉树的中序遍历 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; …

C#,入门教程(28)——文件夹(目录)、文件读(Read)与写(Write)的基础知识

上一篇&#xff1a; C#&#xff0c;入门教程(27)——应用程序&#xff08;Application&#xff09;的基础知识https://blog.csdn.net/beijinghorn/article/details/125094837 C#知识比你的预期简单的多&#xff0c;但也远远超乎你的想象&#xff01; 与文件相关的知识&#xf…

跟着我学Python进阶篇:03. 面向对象(下)

往期文章 跟着我学Python基础篇&#xff1a;01.初露端倪 跟着我学Python基础篇&#xff1a;02.数字与字符串编程 跟着我学Python基础篇&#xff1a;03.选择结构 跟着我学Python基础篇&#xff1a;04.循环 跟着我学Python基础篇&#xff1a;05.函数 跟着我学Python基础篇&#…

# Jenkins:一键部署与备份的终极解决方案

Jenkins&#xff1a;一键部署与备份的终极解决方案 引言 在持续集成和持续部署&#xff08;CI/CD&#xff09;的世界中&#xff0c;Jenkins 作为一个开源自动化服务器&#xff0c;扮演着至关重要的角色。但是&#xff0c;部署和维护 Jenkins 服务往往需要一定的技术知识和时间…

卷积和滤波对图像操作的区别

目录 问题引入 解释 卷积 滤波 问题引入 卷积和滤波是很相似的&#xff0c;都是利用了卷积核进行操作 那么他们之间有什么区别呢&#xff1f; 卷积&#xff1a;会影响原图大小 滤波&#xff1a;不会影响原图大小 解释 卷积 我们用这样一段代码来看 import torch.nn as …

【C++】入门(一)

前言&#xff1a; 本篇博客将带大家认识C&#xff0c;熟悉基本语法 文章目录 认识CC的诞生与发展C 在行业中的运用 一、命名空间1.1 命名空间的定义1.2 命名空间的使用1.3 命名空间的访问 二、C输入&输出输出操作符 <<输入操作符 >>换行符和刷新输出缓冲区关键…

C++入门学习(十二)字符串类型

上一节&#xff08;C入门学习&#xff08;十一&#xff09;字符型-CSDN博客&#xff09;中我们学到如何表示和使用一个字符串&#xff0c;本篇文章是字符串&#xff08;多个字符&#xff09;。 定义字符串主要有两种方式&#xff1a; 第一种&#xff1a; char str[] "…

openGauss学习笔记-203 openGauss 数据库运维-常见故障定位案例-修改索引时只调用索引名提示索引不存在

文章目录 openGauss学习笔记-203 openGauss 数据库运维-常见故障定位案例-修改索引时只调用索引名提示索引不存在203.1 修改索引时只调用索引名提示索引不存在203.1.1 问题现象203.1.2 原因分析203.1.3 处理办法 openGauss学习笔记-203 openGauss 数据库运维-常见故障定位案例-…

28、web攻防——通用漏洞SQL注入HTTP头XFFCOOKIEPOST请求

文章目录 $_GET&#xff1a;接收get请求&#xff0c;传输少量数据&#xff0c;URL是有长度限制的&#xff1b; $_POST&#xff1a;接收post请求&#xff1b; $_COOKIE&#xff1a;接收cookie&#xff0c;用于身份验证&#xff1b; $_REQUEST&#xff1a;收集通过 GET 、POST和C…

Web开发3:数据库使用

欢迎来到Web开发系列的第三篇&#xff01;今天我们将探讨如何在Web开发中使用数据库。数据库是存储和管理数据的重要工具&#xff0c;它在现代应用程序中起着至关重要的作用。无论是社交媒体应用、电子商务平台还是博客网站&#xff0c;数据库都是不可或缺的一部分。 什么是数…

基于DUP的网络聊天室

基于UDP的网络聊天室的使用&#xff08;select&#xff09;完成的服务器端 #include<head.h> typedef struct de {char name[10];struct sockaddr_in cin;struct de* next; }*linklist; //创建节点 linklist a_creat() {linklist p(linklist)malloc(sizeof(struct de));…

C++:基于C的语法优化

C&#xff1a;基于C的语法优化 命名空间命名空间域域作用限定符展开命名空间域 输入输出缺省参数全缺省参数半缺省参数 函数重载参数类型不同参数个数不同参数类型的顺序不同 引用基本语法按引用传递返回引用引用与指针的区别 内联函数autoauto与指针和引用结合 范围for循环nul…

统计灰度图像的灰度值分布并绘制

1、numpy方法 函数&#xff1a; numpy.histogram(a, bins10, rangeNone, normedNone, weightsNone, densityNone) 参数说明&#xff1a; a:输入数据数组&#xff1b;bins:指定统计的区间个数&#xff0c;可以是一个整数&#xff0c;也可以是一个数组&#xff0c;默认值为10…

续签KES证书

MiniO KES&#xff08;密钥加密服务&#xff09;是 MinIO 开发的一项服务&#xff0c;旨在弥合在 Kubernetes 中运行的应用程序与集中式密钥管理服务 &#xff08;KMS&#xff09; 之间的差距。中央 KMS 服务器包含所有状态信息&#xff0c;而 KES 在需要执行与获取新密钥或更新…