CSS中为什么要有层叠机制,可以解决什么问题
Admin 2022-06-10 群英技术资讯 494 次浏览
css中为什么要有层叠机制
因为在css中可能会有多个样式同时影响同一个元素的某个属性,层叠机制可以解决作者(写代码的人),用户(浏览页面的人)和用户代理(一般指浏览器)的样式冲突。
在层叠中每个样式规则都有一个权重值,当其中几条规则同时生效时,权重最大的规则优先。一般来说作者指定的样式权重值高于用户样式权重值,用户样式权重高于客户端(用户代理)权重值。一般权重值跟对象,是否有!important,特异度和位置先后有关。在层叠顺序中,以下权重值从小到大
(1)用户代理样式
(2)用户一般样式
(3)作者一般样式
(4)作者重要样式(!important)
(5)用户重要样式(!important)
(6)如果是两个样式来自相同的代码,如都来自作者(代码),并且它们的样式声明同样重要,则根据特异度来计算,特异度高的会覆盖特异度低的
(7)如果特异度也相同,则越往后的样式优先级越高
为什么用户设置的重要样式比作者重要样式优先级高,这样做的原因是为了方便用户实现一些特殊的要求,例如页面字体大小的调整等。
选择器特异度的计算
(1)如果一个声明出现在元素的style属性中,则将a计为1;
(2)b等于选择器中所有ID选择器加起来的数量和
(3)c等于选择器中所有class选择器和属性选择器,以及伪类选择器加起来的数量和
(4)d等于选择器中所有标签选择器和伪元素选择器加起来的数量和
a-b-c-d即是选择器的特异度,比较顺序从a先比起,谁先大则优先级就越高。
注意:
.box{} /*特异度=0,0,1,0*/ .box div{} /*特异度=0,0,1,1*/ #nav li{} /*特异度=0,1,0,1*/ p:first-line{} /*特异度=0,0,0,2*/ style="" /*特异度=1,0,0,0*/
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了HTML5 Landmark的相关资料,帮助大家了解和学习Landmark,感兴趣的朋友可以了解下
flex的使用方法很简单,只需要将其display属性设置为flex就可以,也可以设置行内的flex。设为Flex布局以后,子元素的float、clear和vertical-align属性将失效。
什么是calc()?学习calc()之前,我们有必要先知道calc()是什么?只有知道了他是个什么东东?在实际运用中更好的使用他。calc()从字面我们可以把他理解为一个函数function。其实cal
今天给大家分享的是关于css实现分割线的内容,我们在文章加入分割线不仅有分割作用,有一定的美化作用。而css实现分割线样式的多种方法,本文小编给大家整理了一些css实现分割线样式的示例,感兴趣的朋友可以参考。
这篇文章主要介绍HTML5中的触摸touch事件,对于触摸事件大家应该都很容易理解,例如我们手指触摸智能手机屏幕时开始触发事件,手机滑动屏幕时触发事件,手指离开屏幕触发结束,这就是一个大致的过程,那么HTML5触摸事件时如何来实现的呢?下面我们来具体了解一下。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008