博客
关于我
CSS选择器的权重
阅读量:593 次
发布时间:2019-03-11

本文共 1621 字,大约阅读时间需要 5 分钟。

ildo感到用户希望将关于CSS选择器权重和样式权重计算的内容进行优化和改写。以下是我对原文的理解和改写结果:

CSS选择器权重与样式权重计算

1. 行间样式、内联样式与外联样式

行间样式、内联样式和外联样式是给CSS样式引入的三种方式,并且它们在权重计算中的先后顺序是:

行间样式 > 内联样式 > 外联样式

2. CSS选择器类型

CSS选择器有多种类型,这些类型决定了样式的应用范围。以下是常见的CSS选择器类型及其特点:

  • ID选择器(#id)

    ID选择器需要确保在HTML标记中定义相应的id名称。ID选择器在样式表中使用#符号表示。与之对应的属性选择器则没有特定的限制。

  • 类选择器(.className)

    类选择器可以通过在HTML元素上定义类名来实现。类选择器在样式表中前面保留一个句点(.)来表示。类选择器适用于多个元素同时应用相同样式。

  • 元素选择器(E)

    元素选择器是最基础的CSS选择器类型,用于直接选择HTML文档中的元素。例如,p可以选择页面中的所有段落元素。

  • 群组选择器

    群组选择器用于将共享相同样式的元素分组。选择多个选择器时,使用逗号(,)进行隔离。例如,div.content p可以选择类为content的所有div元素的后代段落。

  • 通用兄弟选择器(E 〜 F)

    通用兄弟选择器是CSS3新增的选择器类型。它用于在兄弟元素中选择特定元素。例如,ul ~ li会选择所有单独的li元素,如果它们位于同一个父元素内。

  • 相邻兄弟选择器(E + F)

    相邻兄弟选择器用于选择紧接在指定元素之后的相同父元素下的兄弟元素。例如,p + h3会选择每个p元素后面的h3元素。

  • 子元素选择器(E > F)

    子元素选择器用于选择特定祖先元素E的直接子元素F。与后代选择器相比,子元素选择器更严格,只选择直接子元素。例如,div > ul会选择所有div元素的直接子元素中的列表。

  • 后代选择器(E F)

    后代选择器用于选择某个元素的所有后代元素。E F的选择方式更宽泛,F可以是E的子元素、孙元素或更远层次的元素。例如,div body p会选择所有div的后代的子段落元素。

  • 通配符选择器(*)

    通配符是特定范围内最通用的选择器,可以选择页面中任何元素。例如,*会选择所有在层级结构下给定的元素。

  • 伪类和伪元素选择器

    伪类用于在不实际添加内容的情况下为元素应用样式。常用的伪类包括::link(未访问的链接)、:visited(已访问的链接)以及:hover(悬停状态的元素)。

  • 伪元素选择器

    伪元素选择器用于在文档中插入或修改元素内容。例如,::before::after可以用于在元素前后插入自定义内容。

  • 属性选择器

    属性选择器用于根据HTML属性来选择元素。常用的属性选择器格式包括:

    • E[attr]:选择具有指定属性的元素。
    • E[attr=val]:选择具有指定属性值的元素。
    • E[attr~=val]:选择属性值中包含指定单词的元素。
  • 3. 样式权重计算规则

    CSS样式的权重计算遵循以下规则:

  • 第一等:内联样式

    内联样式通过<style>标签直接添加在元素上,权重为1000。

  • 第二等:ID选择器

    使用#符号表示的ID选择器(如#content)的权重为0100。

  • 第三等:类、伪类和属性选择器

    类选择器(如.content)、伪类(如:hover)以及属性选择器的权重为0010。

  • 第四等:元素和伪元素选择器

    元素选择器(如div)、伪元素选择器(如::first-line)和通用选择符的权重为0001。

  • 低等:通配符、子选择器和相邻选择器

    通配符选择器(如*)、子选择器(如div > p)和相邻选择器(如p + h3)的权重为0000。

  • 无权:继承样式

    样式的继承属性没有权重,并且继承的样式仅限于层级关系内的计算。

  • 通过理解CSS选择器的权重和样式权重计算规则,可以更精准地控制网页布局和样式应用效果。

    转载地址:http://lbqtz.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>