首页 web前端 css教程 理解CSS中的样式优先级:css样式优先级顺序的讲解

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

Nov 01, 2018 pm 03:29 PM

本篇文章给大家介绍的是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 id = “sidebar” >
<p class = “bio” >文字在这里</ p>
</ div>
登录后复制
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)

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或声明内联样式。从最小的优先级开始,仅在需要时添加更多。

以上是理解CSS中的样式优先级:css样式优先级顺序的讲解的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1673
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
静态表单提供商的比较 静态表单提供商的比较 Apr 16, 2025 am 11:20 AM

让我们尝试在这里造成一个术语:“静态表单提供商”。你带上html

使Sass更快的概念证明 使Sass更快的概念证明 Apr 16, 2025 am 10:38 AM

在一个新项目开始时,Sass汇编发生在眼睛的眨眼中。感觉很棒,尤其是当它与browsersync配对时,它重新加载

每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom 每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom Apr 17, 2025 am 10:55 AM

在本周的平台新闻综述中,Chrome引入了一个用于加载的新属性,Web开发人员的可访问性规范以及BBC Move

带有HTML对话框元素的一些动手 带有HTML对话框元素的一些动手 Apr 16, 2025 am 11:33 AM

这是我第一次查看HTML元素。我已经意识到了一段时间,但是尚未将其旋转。它很酷,

纸张形式 纸张形式 Apr 16, 2025 am 11:24 AM

购买或建造是技术的经典辩论。自己构建东西可能会感觉更便宜,因为您的信用卡账单上没有订单项,但是

'订阅播客”链接应在哪里? '订阅播客”链接应在哪里? Apr 16, 2025 pm 12:04 PM

有一段时间,iTunes是播客中的大狗,因此,如果您将“订阅播客”链接到喜欢:

托管您自己的非JavaScript分析的选项 托管您自己的非JavaScript分析的选项 Apr 15, 2025 am 11:09 AM

有很多分析平台可帮助您跟踪网站上的访问者和使用数据。也许最著名的是Google Analytics(广泛使用)

See all articles