定义CSS样式时,经常出现两个或更多样式规则应用在同一元素上的情况。此时CSS就会根据样式规则的权重,优先显示权重最高的样式。CSS优先级指的就是CSS样式规则的权重。在网页制作中,CSS为每个基础选择器都指定了不同的权重,方便我们添加样式代码。为了深入理解CSS优先级,我们通过一段示例代码进行分析。CSS样式代码如下:
p{ color:red;} /*标签样式*/
.blue{ color:green;} /*class样式*/
theader{ color:blue;} /*id样式*/CSS样式代码对应的HTML结构为:
帮帮我,我到底显示什么颜色?
在上面的示例代码中,使用不同的选择器对同一个元素设置文本颜色,这时浏览器会根据CSS选择器的优先级规则解析CSS样式。为了便于判断元素的优先级,CSS为每一种基础选择器都分配了一个权重,我们可以通过虚拟数值的方式为这些基础选择器匹配权重。假设标签选择器具有权重为1.类选择器具有权重则为10,id选择器具有权重则为l00。这样id选择器“#header”就具有最大的优先级,因此文本显示为蓝色。
对于由多个基础选择器构成的复合选择器(并集选择器除外),其权重可以理解为这些基础选择器权重的叠加。例如,下面的CSS代码。
p strong{color:black} /*权重为:1+1*/
strong.blue{color:green;} /*权重为:1+10*/
.father strong{color:yellow} /*权重为:10+1*/
p.father strong{color:orange;} /*权重为:1+10+1*/
p.father .blue{color:gold;} /*权重为:1+10+10*/
theader strong{color:pink;} /*权重为:100+1*/
#header strong.blue{color:red;} /*权重为:100+1+10*/对应的HTML结构为:
文本的颜色
这时,CsS代码中的“#header strong.blue”选择器的权重最高,文本颜色将显示为红色。此外,在考虑权重时,我们还需要注意一些特殊的情况。
(1)继承样式的权重为0
在嵌套结构中、h不管父元素样式的权重多大,被子元素继承时,它的权重都为0,也就是说子元素定义的样式会覆盖继承来的样式。例如,下面的CSS样式代码。
strong{color:red;}
#header{color:green;}CSS样式代码对应的HTML结构如下:
继承样式不如自己定义的权重大
在上面的代码中,虽然“#header”具有权重100,但被标签继承时权重为0。而“strong”选择器的权重虽然仅为1,但它大于继承样式的权重,所以页面中的文本显示为红色。
(2)行内样式优先
应用style属性的元素,其行内样式的权重非常高。换算为数值,我们可以理解为远大于100。因此行内样式拥有比上面提到的选择器都高的优先级。
(3)权重相同时,CSS的优先级遵循就近原则
也就是说,靠近元素的样式具有最大的优先级,或者说按照代码排列上下顺序,排在最下边的样式优先级最大。例如,下面为外部定义的CSS示例代码。
/*CSS文档,文件名为style_red.css*/
#header{color:red;} /*外部样式*/对应的HTML结构代码如下:
CSS优先级
/*引入外部
定义的CSS代码*/
/*内嵌式样式*/
权重相同时,就近优先
在上面的示例代码中,第2行代码通过外链式引入CSS样式,该样式设置文本样式显示为红色。第3~5行代码通过内嵌式引入CSS样式,该样式设置文本样式显示为灰色。
上面的页面被解析后,段落文本将显示为灰色,即内嵌式样式优先。这是因为内嵌样式比外链式样式更靠近HTML.元素。同样的道理,如果同时引用两个外部样式表,则排在下面的样式表具有较大的优先级。如果此时将内嵌样式更改为:
p{color:gray;} /*内嵌式样式*/此时外链式的id选择器和嵌入式的标签选择器权重不同,“#header”的权重更高,文字将显示为外部样式定义的红色。
(4)CSS定义“limportant”命令,会被赋予最大的优先级
当CSS定义了“limportant”命令后,将不再考虑权重和位置关系,使用“limportant”的标签都具有最大优先级。例如,下面的示例代码。
#header{color:red!important;}应用此样式的段落文本显示为红色,因为“limportant”命令的样式拥有最大的优先级。需要注意的是,“limportant”命令必须位于属性值和分号之间,否则无效。
复合选择器的权重为组成它的基础选择器权重的叠加,但是这种叠加并不是简单的数字之和。下面通过一个案例来具体说明,如例1所示。
例1 examplel1.html
复合选择器权重的叠加
文本的样式
例1共使用了11对 运行例1,效果如下所示。 在上图中,文本并没有像预期的那样添加下画线,而显示了类选择器“.inner”定义的删除线。可见,无论在外层添加多少个标签,复合选择器的权重无论为多少个 写这个,主要是对自己学习python知识的一个总结,也是加深自己的印象。变量(英文:variable),也叫标识符。在python中,变量的命名规则有以下三点:>变量名只能包含字母、数字和下划线... python是一个动态编译类编程语言,所以程序在运行前不需要如C语言的先行编译动作,因此也只有在程序运行过程中才能发现程序的问题。基于此,python的变量就有一定的命名规范。python作为当前热门... 2.1什么是变量?在编程中,变量就像一个存放数据的容器,它可以存储各种信息,并且这些信息可以被读取和修改。想象一下,变量就如同我们生活中的盒子,你可以把东西放进去,也可以随时拿出来看看,甚至可以换成... 在科研过程中,大家用到最多的可能就是“三线表”。“三线表”,一般主要由三条横线构成,当然在变量名栏里也可以拆分单元格,出现更多的线。更重要的是,“三线表”也是一种数据记录规范,以“三线表”形式记录的数... 学习Python中的变量和数据类型至关重要,因为它们构成了Python编程的基石。以下是帮助您了解Python中的变量和数据类型的分步指南:1.变量:变量在Python中用于存储数据值。它们充... 反引号`无任何作用。传说Python3中它被移除是因为和单引号字符'太相似。波浪号~(按位取反符号)~被称为取反或补码运算符。它放在我们想要取反的对象前面。如果放在一个整数n... 别再被小名词坑哭了:Python新手常犯的那些隐蔽错误,我用同事的真实bug拆给你看我记得有一次和同事张姐一起追查一个看似随机崩溃的脚本,最后发现罪魁祸首竟然是她把变量命名成了list。说实话... 在当今的互联网软件开发领域,SpringBoot无疑是最为热门和广泛应用的框架之一。它以其强大的功能、便捷的开发体验,极大地提升了开发效率,成为众多开发者构建Web应用程序的首选。而在Spr... Python中下划线()是一个有特殊含义和用途的符号,它可以用来表示以下几种情况:1在解释器中,下划线(_)表示上一个表达式的值,可以用来进行快速计算或测试。例如:>>>2+... 引言:开启Shell编程大门Shell作为用户与Linux内核之间的桥梁,为我们提供了强大的命令行交互方式。它不仅能执行简单的文件操作、进程管理,还能通过编写脚本实现复杂的自动化任务。无论是... 目录1.变量的命名原则3.内置函数尽量不要做变量4.删除变量和垃圾回收机制5.结语1.变量的命名原则①由英文字母、_(下划线)、或中文开头②变量名称只能由英文字母、数字、下画线或中文字所组成。③英文字... src/main.rs://函数定义fnadd(a:i32,b:i32)->i32{a+b//末尾表达式}fnmain(){leta:i3... 变量的命名不是想怎么起就怎么起的,而是有一套固定的规则的。具体规则:1.名字要合法:变量名必须是由字母、数字或下划线组成。例如:a,a1,a_1。2.开头不能是数字。例如:可以a1,但不能起1a。3.... Unsafe的必要性Rust的所有权系统和类型系统为我们提供了强大的安全保障,但在某些情况下,我们需要突破这些限制来:与C代码交互实现底层系统编程优化性能关键代码实现某些编译器无法验证的安全操作Rus... 在编程的世界里,内存管理就如同幕后的精密操控者,确保程序的高效运行。Python作为一种广泛使用的编程语言,其内存管理机制既巧妙又复杂,为开发者们提供了便利的同时,也展现了强大的底层控制能力。一、P...
相关推荐
