伪类和伪元素

本文涉及的产品
Serverless 应用引擎 SAE,800核*时 1600GiB*时
容器镜像服务 ACR,镜像仓库100个 不限时长
可观测监控 Prometheus 版,每月50GB免费额度
简介: 伪类和伪元素是 CSS 中用于扩展选择器功能的两种特性,无需额外的 HTML 标签即可创建复杂的样式规则。

伪类和伪元素是 CSS 中用于处理选择器的两种特殊功能。它们允许开发者在样式中创建更复杂和灵活的规则,而无需在 HTML 文档中添加额外的标签。

伪类 (Pseudo-class)

伪类作用于元素的特定状态。它们用于选择元素在某种条件下的样式,例如鼠标悬停或焦点状态。伪类以冒号(:)开头。

常见的伪类示例:

  1. :hover: 当用户将鼠标悬停在元素上时应用的样式。

    a:hover {
         
        color: red; /* 当鼠标悬停在链接上时,将文本颜色设置为红色 */
    }
    
  2. :active: 当元素处于活动状态时应用的样式,例如当用户按下鼠标按钮。

    a:active {
         
        color: blue; /* 当链接被点击时,将文本颜色设置为蓝色 */
    }
    
  3. :focus: 当元素获得焦点时应用的样式,通常用于输入框。

    input:focus {
         
        border: 2px solid green; /* 当输入框获得焦点时,将边框设置为绿色 */
    }
    
  4. :nth-child(n): 选择父元素下的第 n 个子元素。

    li:nth-child(2) {
         
        font-weight: bold; /* 将每个父元素下的第二个列表项设置为粗体 */
    }
    

伪元素 (Pseudo-element)

伪元素用于选择元素的特定部分,允许开发者在实际的 DOM 结构中没有定义的情况下添加样式。伪元素以双冒号(::)开头(尽管单冒号(:)也被广泛支持)。

常见的伪元素示例:

  1. ::before: 在元素的内容前插入内容。

    p::before {
         
        content: "注意:"; /* 在每个段落前插入“注意:” */
        font-weight: bold;
    }
    
  2. ::after: 在元素的内容后插入内容。

    p::after {
         
        content: " — 结束"; /* 在每个段落后插入“— 结束” */
    }
    
  3. ::first-line: 选择文本的第一行,用于对首行文本应用特殊样式。

    p::first-line {
         
        font-weight: bold; /* 将每个段落的第一行加粗 */
    }
    
  4. ::first-letter: 选择文本的第一个字母。

    p::first-letter {
         
        font-size: 2em; /* 将段落的第一个字母的字体大小设置为 2 倍 */
    }
    

总结

  • 伪类:用于表示元素的特定状态,通常与用户的交互有关,如悬停、焦点等,以冒号(:)表示。
  • 伪元素:用于选择元素的特定部分,允许对元素的内容进行样式处理,以双冒号(::)表示。

二者结合使用,可以极大丰富网页的视觉效果和交互体验。

相关文章
|
27天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
3天前
|
人工智能 Rust Java
10月更文挑战赛火热启动,坚持热爱坚持创作!
开发者社区10月更文挑战,寻找热爱技术内容创作的你,欢迎来创作!
360 14
|
19天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
6天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
21天前
|
人工智能 IDE 程序员
期盼已久!通义灵码 AI 程序员开启邀测,全流程开发仅用几分钟
在云栖大会上,阿里云云原生应用平台负责人丁宇宣布,「通义灵码」完成全面升级,并正式发布 AI 程序员。
|
23天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2592 22
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
5天前
|
存储 人工智能 搜索推荐
数据治理,是时候打破刻板印象了
瓴羊智能数据建设与治理产品Datapin全面升级,可演进扩展的数据架构体系为企业数据治理预留发展空间,推出敏捷版用以解决企业数据量不大但需构建数据的场景问题,基于大模型打造的DataAgent更是为企业用好数据资产提供了便利。
181 2
|
3天前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
105 65
|
6天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
330 2
|
23天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1580 17
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码