0

0

理解CSS中的样式优先级:css样式优先级顺序的讲解

不言

不言

发布时间:2018-11-01 15:29:31

|

7840人浏览过

|

来源于php中文网

原创

本篇文章给大家介绍的是css样式优先级,带大家深入理解一下css样式优先级的顺序。

理解CSS中的样式优先级:css样式优先级顺序的讲解

您是否遇到过尝试将css样式应用于元素的情况,但是却没有效果?页面似乎忽略了你定义的CSS,但你可能无法弄清楚原因。也许你会让!important或添加内联样式作为最后的实现手段。但实际上你遇到的问题很可能是css优先级之一。(推荐课程:css视频教程

更好地理解哪些css样式优先使用可以更清晰更有组织的来写css代码,所以让我们看看控制给定html元素的三个css规则:

css优先级计算

立即学习前端免费学习笔记(深入)”;

css继承

css层叠

学习这些规则将使您的CSS开发更上一层楼。

优先级计算

想象一下,你的html包含一个应用了一类“生物”的段落。您还有以下两个css规则:

p { font-size :12px }
p.bio { font-size :14px }

你希望段落中的文字大小是12px还是14px?在这种情况下你可以猜测它将是14px。css(p.bio)的第二行比你的class =“bio”段更具体。然而,有时优先级并不容易看到。

例如,考虑以下html和css

文字在这里

div p.bio { font-size :14px }
#sidebar p { font-size :12px }

乍一看,第一行css可能看起来更具体,但实际上上面的第二行更符合段落的字体大小。这是为什么?

要回答这个问题,我们需要考虑优先级规则。

通过计算css的各种成分并以(a,b,c,d)形式表达它们来计算特异性。这将通过一个例子更清楚,但首先是组件。

元素,伪元素:d = 1 - (0,0,0,1)

类,伪类,属性:c = 1 - (0,0,1,0)

Id:b = 1 - (0,1,0,0)

内联样式:a = 1 - (1,0,0,0)

id比类更具体而不是元素。

您可以通过计算上述每一项并将a,b,c或d加1来计算优先级。同样重要的是要注意0,0,1,0比0,0,0,15更具体。让我们看一些例子来使计算更清晰。

p:1个元素 - (0,0,0,1)

div:1个元素 - (0,0,0,1)

#sidebar:1个id - (0,1,0,0)

div#sidebar:1个元素,1个id - (0,1,0,1)

ZYCH自由策划企业网站管理系统06 Build210109
ZYCH自由策划企业网站管理系统06 Build210109

ZYCH自由策划企业网站管理系统是一个智能ASP网站管理程序,是基于自由策划企业网站系列的升级版,结合以往版本的功能优势,解决了频道模板不能自由添加删减的问题,系统开发代码编写工整,方便读懂,系统采用程序模板分离式开发。方便制作模板后台模板切换,模板采用动态编写,此模板方式写入快,代码编写自由,即能满足直接使用也能满足二次开发。全新的后台界面,不管是在程序的内部结构还是界面风格及CSS上都做了大量

下载

div#sidebar p:2个元素,1个id - (0,1,0,2)

div#sidebar p.bio:2个元素,1个类,1个id - (0,1,1,2)

让我们再看一下上面的例子

div p.bio { font-size :14px }  - (0,0,1,2)
#sidebar p { font-size :12px }  - (0,1,0,1)

第二个具有更高的优先级,因此优先。

在我们前进之前的最后一点。重要性胜过优先级,当你使用!important标记css属性时,你会覆盖优先级规则等等

div p.bio { font-size :14px !important }    
#sidebar p { font-size :12px }

表示上面的第一行css优先于第二行而不是第二行。!important仍然是围绕基本规则的特殊性,如果您了解规则的运作方式,您应该永远不需要。

继承

继承背后的想法相对容易理解。元素从其父容器继承样式。如果将body标签设置为使用color:red,那么除非另有说明,否则正文中所有元素的文本也将为红色。

但是,并非所有css属性都是继承的。例如,边距和填充是非继承属性。如果在div上设置边距或填充,则div内的段落不会继承您在div上设置的边距和填充。该段落将使用默认的浏览器边距和填充,直到您另外声明。

但是,您可以显式设置属性以从其父容器继承样式。例如,您可以声明

p { margin :inherit ; 填充:继承 }

然后你的段落将从它的包含元素继承。

层叠

在最高级别,层叠是控制所有css优先级的,并且如下工作。

1、查找适用于相关元素和属性的所有css声明。

2、按原点和重量排序。Origin指的是声明的来源(作者样式,用户样式,浏览器默认值),权重指的是声明的重要性。(作者的权重大于用户的权重大于默认值。!important比正常声明更重要)

3、计算优先级

4、如果上述所有规则中的两个规则相同,那么最后一个规则获胜。嵌入在html中的CSS总是在外部样式表之后,而不管html中的顺序如何。

上面的#3很可能是你最需要注意的。使用#2只需了解您的样式将覆盖用户设置浏览器的方式,除非他们将规则设置为重要。

还要意识到您的样式将覆盖浏览器默认值,但这些默认值确实存在,并且通常会导致跨浏览器问题。使用重置文件,如Eric Meyer的CSS重置或Yahoo的YUI重置CSS有助于将默认样式排除在等式之外。

总结

希望以上内容有助于理清您的一些CSS优先级问题。大多数情况下,如果你的风格存在冲突,问题将归结为优先级。有时你还没有声明一些css,但是一个元素的行为方式你并不期望它可能从父容器或浏览器的默认样式继承了某些css。

声明css时的一般经验法则是声明具有最小优先级的属性来设置元素的样式。例如,使用#sidebar而不是div#sidebar。我承认打破这个一般规则远远超过我应该,但通过使用所需的最小优先级,它将使您更容易通过声明更具体的样式来覆盖样式。

如果您使用最具优先级,您可能会在以后遇到问题并发现自己必须添加不必要的HTML以便能够添加更多优先级,或者您可能会发现自己不再使用!important或声明内联样式。从最小的优先级开始,仅在需要时添加更多。

相关专题

更多
Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

15

2026.01.13

PHP 高性能
PHP 高性能

本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

34

2026.01.13

MySQL数据库报错常见问题及解决方法大全
MySQL数据库报错常见问题及解决方法大全

本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

PHP 文件上传
PHP 文件上传

本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

PHP缓存策略教程大全
PHP缓存策略教程大全

本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

6

2026.01.13

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

交互式图表和动态图表教程汇总
交互式图表和动态图表教程汇总

本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

45

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

5

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS教程
CSS教程

共754课时 | 18.9万人学习

HTML+CSS 快速上手
HTML+CSS 快速上手

共95课时 | 15.5万人学习

前端小白零基础入门HTML5+CSS3
前端小白零基础入门HTML5+CSS3

共361课时 | 33万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号