CSS优先级
一.CSS代码出现的几个位置
多重样式(Multiple Styles):如果外部样式、内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况。
一般情况下,优先级如下:(外部样式)External style sheet <(内部样式)Internal style sheet <(内联样式)Inline style
还有一种不常用的CSS导入方式:@import url(mycss/haha.css),这种方式是页面显示出来之后在加载css,所以页面一开始没有css定义显示比较混乱,过了一会儿才加载css显示正常,页面会闪烁一下.
二.选择器的优先级
每个选择器都有一个优先级.这个优先级可以定义为五元组(a,b,c,d,e)
第一个数字(a)表示style属性,即内联样式。
第二个数字(b)表示id选择器,b表示id选择器的个数。
第三个数字(c)表示class选择器,c表示类及伪类的个数,包括class(.btn)和属性css选择器(比如li[id=red])。
第四个数字(d)表示tag选择器,d表示元素和伪元素(如first-child)的个数。
第五个数字(e)表示这个句子是整个css系统中的第几个选择器.
当判断一个选择器的优先级时,按照这五元组进行比较,第一个相同比较第二个,前两个相同比较第三个...第五个数字肯定不同,于是优先级就排出来了.其实比较时比较五个数字比较费力,不如直接将他们乘以权值映射为一个int.浏览器实现时到底采用什么方式并不重要,重要的是明白这个道理.下面给出浏览器解析css和渲染元素的伪代码.
def initSelectors():
for selector in css:
selector.priority=0
#这是第几个选择器
selector.priority+=css.indexOf(selector)
if selector is important:
selector.priority+=10000
if selector is inline:#内联样式至高无上,如果为内联样式,其它几个的值肯定是0
selector.priority+=len(css)**4
else:
for i in selector:
if i is idSelector:
selector.priority+=len(css)**3
elif i is classSelector:
selector.priority+=len(css)**2
elif i is tagSelector:
selector.priority+=len(css)
def renderElements():
for element in html:
attrTable={}
for selector in selectors:
if element is selector:
for attrbute in selector:
if attrTable[attrbute]==null or attrTable[attrbute].priority<selector.priority:
attrTable[attrbute]=selector[attrbute]
attrTable[attrbute].priority=selector.priority
render(element,attrTable)
通用css选择器(*)是0优先级。
如果两个CSS选择器有同样的优先级,在样式表中后面的那个起作用。
CSS选择器只有4种:
- 内联样式
style='font-size:18px;'
内联样式其实相当于无名选择器 - id选择器
- class选择器,伪类选择器
- tag选择器,伪元素选择器
三.选择器与选择器之间的三种连接关系
- 空格表示后代
- +表示兄弟
- >表示子代
四.最近jquery中用到的几个选择器
$('.answer input[value=0]').attr('checked',true)
$(".question_answers").find('input:first').attr('checked',true)
$("button[id^=peer]").click();
$("label:contains('正确'):not(:contains('部分'))").each(function(){$(this).prev().attr('checked',true)})
CSS优先级的更多相关文章
- css选择器及css优先级
三个css选择器:id选择器#test1{ }.class选择器.test2{ }.标签选择器div{ }对三个div:<div>我是普通div</div>.<div i ...
- 关于CSS的优先级,CSS优先级计算
原则一: 继承不如指定原则二: #id > .class > 标签选择符原则三:越具体越强大原则四:标签#id >#id ; 标签.class > .class CSS优先级权 ...
- css 优先级 机制
多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External style sheet ...
- z-index、display、selector选择器优先级css优先级面试用到
z-index:控制元素叠放顺序,哪个z-index数值越大,那个优先被叠放在上面. relative.absolute.fixed这三种情况可以使用z-index. static不可以使用. dis ...
- css优先级和层叠
css优先级和层叠 1.优先级 计算方法: a.行内样式 b.id选择器的数量 c.类,伪类和属性选择器的数量 d.标签选择器和伪元素选择 ...
- 使用background和background-image对CSS优先级造成影响
在写一个关于背景图的CSS时候发现一个奇怪的现象, 原图: 如下代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...
- CSS优先级算法是如何计算?
CSS的specificity特性或非凡性,它是一个衡量css优先级的一个标准, 既然的标准就有判定规定和计算方式,specificity用一个四位数来表示, 更像四级从左到右,左的最大级,一级大于一 ...
- CSS优先级总结(转载)
样式的优先级 多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External styl ...
- css优先级计算
主要的css选择器有id,class,tag,[],:,::等,而通常需要对其优先级进行判断的有id,class,tag,另外内联样式和!important也和css的优先级有关系. 如果将这五种不同 ...
- css 优先级
css优先级的四大原则: 原则一: 继承不如指定 如果某样式是继承来的永远不如具体指定的优先级高.例子1:CODE:<style type="text/css"> &l ...
随机推荐
- ASP.NET 中 OutputCache 指令参数详解
使用@ OutputCache指令使用@ OutputCache指令,能够实现对页面输出缓存的一般性需要.@ OutputCache指令在ASP.NET页或者页中包含的用户控件的头部声明.这种方式非常 ...
- 在基于MVC的Web项目中使用Web API和直接连接两种方式混合式接入
在我之前介绍的混合式开发框架中,其界面是基于Winform的实现方式,后台使用Web API.WCF服务以及直接连接数据库的几种方式混合式接入,在Web项目中我们也可以采用这种方式实现混合式的接入方式 ...
- 《c# 从入门经典》 (第6版) - 变量和表达式
1,程序就是对一系列数据的操作:数据最终是存储在内存中的0和1数据流:我们在桌面上的任何操作都会改变内存中的数据. 2,变量存储在计算机中占用着一定的内存空间 bit: 位,计算机的最小存储单位,存储 ...
- dpkg:处理软件包dradis (--configure)时出错
dpkg:处理软件包dradis (--configure)时出错!解决方案:1.将info文件夹更名%mv /var/lib/dpkg/info /var/lib/dpkg/info_old2.新建 ...
- Linux设置开机启动
开机启动 解决服务器重启,比如断点,导致服务没有启动的烦恼 1.整理机器上面运行的服务,编些成sh脚本,文件为:/home/rc/exec.sh #加载环境变量 source /etc/profi ...
- JS+CSS3人物奔跑动画
查看效果:http://hovertree.com/texiao/jquery/58/ 效果图: 代码: <!DOCTYPE html> <html> <head> ...
- 基于rem的移动端自适应解决方案
代码有更新,最好直接查看github: https://github.com/finance-sh/adaptive adaptivejs原理: 利用rem布局,根据公式 html元素字体大小 = d ...
- Android 手机卫士--获取联系人信息并显示与回显
前面的文章已经实现相关的布局,本文接着进行相关的功能实现 本文地址:http://www.cnblogs.com/wuyudong/p/5951794.html,转载请注明出处. 读取系统联系人 当点 ...
- [问题]apparmor 问题导致mysql切换datadir目录失败
问题: 在mysql切换datadir后,mysql服务无法启动.出现错误说plugin表无法读取,需要用mysql_upgrade创建.但是其实不是这个问题. 原因: apparmor 会限制程序对 ...
- 随机生成长度为len的密码,且包括大写、小写英文字母和数字
一道华三面试题,随机生成长度为len的密码,且包括大写.小写英文字母和数字,主要Random类的使用,random.nextInt(len)表示生成[0,len)整数.具体实现见下面代码,已经很详细了 ...