关于CSS层叠机制
谈到层叠机制,首先我们要知道什么是声明冲突。
声明冲突有三个条件:①多个选择器选中同一个元素;②声明块里的属性相同;③属性的属性值不同。同时满足这三点时就会产生声明冲突。比如下图html代码:
<div>
<p><span>hello word</span></p>
</div>
他的css文件如下:
span{
color:red;
}
p>span{
color:blue;
}
div>p>span{
color:green;
}
此时就会产生声明冲突。
浏览器只会挑其中一个选择器中的样式来渲染网页,关于如何挑选就是层叠机制的内容。
层叠机制:是一种机制,当发生声明冲突时自动触发,浏览器通过层叠机制解决声明冲突。主要内容为:
1、首先比较样式表的优先级。
样式表的优先级受来源和重要性影响。
来源:作者样式表>浏览器默认样式表
重要性:针对作者样式表而言的,有!important>无重要样式声明
因此作者重要>作者普通>浏览器默认,比如:
<div>
<p>
<span>
<a href="http://www.baidu.com">百度一下</a>
</span>
</p>
</div>
a{
color: green!important;
}
a{
color:red;
}
a标签浏览器默认为蓝色,普通定义了样式为红色,重要样式定义了绿色,因此最终被渲染成绿色。
2.比较特殊性,也叫权重or特指度。
规则:行内样式>ID选择器>类、伪类、属性选择器>元素、伪元素选择器>通配符选择器
当发生声明冲突且他们优先级相同时,我们比较特殊性,通过上述规则,我们对每一个样式会产生一个四元数组(a,b,c,d),其中:
a:行内样式为1,否则为0
b:ID选择器的个数
c:类、伪类、属性选择器的个数
d:元素、伪元素选择器的个数
依次从前往后比,大的胜出,一旦胜出,无需再比较之后的数值。例如:
页面中的一个a元素:
<div class="main">
<div>
<p id="nav">
<span class="home">
<a href="http://www.baidu.com">百度一下</a>
</span>
</p>
</div>
</div>
/*样式1*/
a{
color: green;
}
/*样式2*/
.foo{
color:yellow;
}
/*样式3*/
#bar{
color: red;
}
/*样式4*/
.main>div #nav *.home a:link{
color:pink;
}
样式1: 0,0,0,1;
样式2: 0,0,1,0;
样式3: 0,1,0,0;
样式4: 0,1,3,2;
3. 比较源次序。当优先级和特殊性都一样时,书写顺序上,后写的会覆盖先写的。
以上,就是层叠机制的主要内容。
以下,写几个常见的误区;
误区一:认为ID选择器适用范围最小,因此特殊性最高。这种说法是错的,应该按照“四元数组”法判断。
误区二:
<div id="bar">
<a href="http://www.baidu.com">百度一下</a>
</div>
/*样式1*/
#bar{
color: red;
}
/*样式2*/
a{
color: green;
}
认为a标签最后是红色。这里其实样式1和样式2并没有发生声明冲突,由于浏览器中对a元素有默认的样式,作者样式表也写了对a元素的样式,因此没有发生继承。产生声明冲突的是浏览器的默认样式和作者样式表中的样式2,优先级比较知道样式2胜出,无需比较特殊性。
欢迎补充。
关于CSS层叠机制的更多相关文章
- css考核点整理(二)-css层叠机制
css层叠机制 外边距重叠就是margin-collapse. 在CSS当中,相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的外边距可以结合成一个单独的外边距.这种合并外边距的方式被称为折叠,并且因 ...
- css层叠机制说明
css通过建立与文档的关联而实施效果.文档结构重要性不言而喻,对于建立良好的内容索引.提高可维护性.较好的可访问性:另,利于css选择器选择.继承机制. 概要地讲,层叠机制是处理对文档上应用样式时解决 ...
- 三.CSS层叠机制
概述 层叠就是对样式的层叠.是某种样式在样式表中逐层叠加的过程.让浏览器对某个标签特定属性值的多个来源,最终确定使用那个值.层叠是整个CSS的核心机制. HTML文档样式的来源 1.浏览器默认样式,每 ...
- CSS引用方式及样式层叠机制
CSS引用方式有3种,三种分别为:外部引入.内部引入.行内样式,下面一 一进行介绍. 1.外部引入:CSS代码在一个独立的文件中,HTML通过Link标签引入到页面. 代码格式:<link re ...
- CSS中的样式层叠机制Cascade
CSS中的样式层叠机制Cascade 一.样式冲突 样式冲突是CSS渲染过程要解决的一个关键问题,样式冲突主要由两个原因造成: 元素包含了不同对象所赋予的样式:浏览器.用户.作者.其中,浏览器样式 ...
- 层叠机制和继承的概念以及CSS中选择器的优先级
层叠机制: 一个元素的某个特定的样式属性可能来自行间的style属性.内联样式表或者外部引入的样式表,以及浏览器自定义的样式,还有就是继承自父元素的样式,但是最终只会选择其中的某一个来表示,这个选择的 ...
- CSS层叠
前面的话 层叠样式表CSS最基本的一个特性就是层叠.冲突的声明通过层叠进行排序,由此确定最终的文档表示.而这个过程的核心就是选择器及其相关声明的特殊性.重要性.来源及继承机制.本文将详细介绍CSS层叠 ...
- css层叠规则,优先级算法
前言 层叠样式表CSS最基本的一个特性就是层叠.冲突的声明通过层叠进行排序,由此确定最终的文档表示.而这个过程的核心就是选择器及其相关声明的特殊性.重要性.来源及继承机制.本文将详细介绍CSS层叠 特 ...
- css层叠规则(层叠样式表)
CSS层叠规则: 1.找出所有相关的规则,这些规则都包含与一个给定元素匹配的选择器. 2.按权重(!important)和来源对应用到给定元素的所有声明进行排序. 3.按特殊性对应用到给定元素的所有声 ...
随机推荐
- html初识form表单
定义和用法 <form> 标签用于为用户输入创建 HTML 表单. 表单能够包含 input 元素,比如文本字段.复选框.单选框.提交按钮等等. 表单用于向服务器传输数据.通过submit ...
- [Spring实战笔记]4面向切面编程的Spring-代理
代理 代理(Proxy)是一种设计模式,可以在目标对象实现的基础上,扩展目标对象的功能. 代理对象是对目标对象的扩展,并会调用目标对象. 三种代理模式 静态代理 100% 代理对象与目标对象要实现相同 ...
- redis哨兵集群
Sentinel 哨兵 修改src下的sentinel.conf文件 , 配置端口 :port:随便 daemonize yes 配置主服务器的ip 和端口 我们把监听的端口修改成7000,并且 ...
- ECMA262学习笔记(二)
Property特性:特性用于定义和解释命名属性的状态. ECMAScript建立执行环境: 解释执行全局代码或使用eval函数输入的代码会创建并进入一个新的执行环境.每次调用ECMA脚本代码定义的函 ...
- Dual Attention Network for Scene Segmentation
Dual Attention Network for Scene Segmentation 原始文档 https://www.yuque.com/lart/papers/onk4sn 在本文中,我们通 ...
- 《笨方法学Python》加分题29
加分练习猜一猜 “if 语句” 是什么,他有什么作用.在做下一道题之前,试着用自己的话回答下面的问题: 你认为 if 对他下一行代码做了什么?为什么 if 语句的下一行需要 4 个空格缩进?如果不缩进 ...
- 201771010134杨其菊《面向对象程序设计java》第十二周学习总结
第十二周学习总结 第一部分:理论知识 内容概要: AWT与Swing简介:框架的创建:图形程序设计: 显示图像: 1.AWT组件: 2.Swing 组件层次关系 3 .AWT与Swing的关系:大部分 ...
- [模拟][NOIP2015]神奇的幻方
神奇的幻方 题目描述 幻方是一种很神奇的N∗ N矩阵:它由数字 1,2,3, … … , N ∗ N 构成,且每行.每列及两条对角线上的数字之和都相同. 当 N为奇数时,我们可以通过以下方法构建一个幻 ...
- python3 第二十七章 - 内置函数之str相关
Python 的字符串常用内建函数如下: 序号 方法及描述 实例 1 capitalize()将字符串的第一个字符转换为大写 2 center(width, fillchar) 返回一个指定的宽度 ...
- 计算pi的精度+进度条显示
步骤1:安装tqdm 首先,要打开cmd,输入指令,不断找到python文件的路径,知道找到Scripts,然后分别打入pip install pygame和pip install tqdm 如下图 ...