一.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优先级的更多相关文章

  1. css选择器及css优先级

    三个css选择器:id选择器#test1{ }.class选择器.test2{ }.标签选择器div{ }对三个div:<div>我是普通div</div>.<div i ...

  2. 关于CSS的优先级,CSS优先级计算

    原则一: 继承不如指定原则二: #id > .class > 标签选择符原则三:越具体越强大原则四:标签#id >#id ; 标签.class > .class CSS优先级权 ...

  3. css 优先级 机制

    多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External style sheet ...

  4. z-index、display、selector选择器优先级css优先级面试用到

    z-index:控制元素叠放顺序,哪个z-index数值越大,那个优先被叠放在上面. relative.absolute.fixed这三种情况可以使用z-index. static不可以使用. dis ...

  5. css优先级和层叠

    css优先级和层叠 1.优先级    计算方法:        a.行内样式        b.id选择器的数量        c.类,伪类和属性选择器的数量        d.标签选择器和伪元素选择 ...

  6. 使用background和background-image对CSS优先级造成影响

    在写一个关于背景图的CSS时候发现一个奇怪的现象, 原图: 如下代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...

  7. CSS优先级算法是如何计算?

    CSS的specificity特性或非凡性,它是一个衡量css优先级的一个标准, 既然的标准就有判定规定和计算方式,specificity用一个四位数来表示, 更像四级从左到右,左的最大级,一级大于一 ...

  8. CSS优先级总结(转载)

    样式的优先级 多重样式(Multiple Styles):如果外部样式.内部样式和内联样式同时应用于同一个元素,就是使多重样式的情况. 一般情况下,优先级如下: (外部样式)External styl ...

  9. css优先级计算

    主要的css选择器有id,class,tag,[],:,::等,而通常需要对其优先级进行判断的有id,class,tag,另外内联样式和!important也和css的优先级有关系. 如果将这五种不同 ...

  10. css 优先级

    css优先级的四大原则: 原则一: 继承不如指定 如果某样式是继承来的永远不如具体指定的优先级高.例子1:CODE:<style type="text/css"> &l ...

随机推荐

  1. import matplolib 时出现"This probably means that tk wasn't installed properly."的解决方法

    最近又添了一台新电脑,配置好各个依赖环境后想用matplotlib画个图,结果报出下面的错误 根据报错分析,应该是C:/Python27/tcl/tk8.5/tk.tcl这个文件出问题了,根据图中的信 ...

  2. 用python实现最长公共子序列算法(找到所有最长公共子串)

    软件安全的一个小实验,正好复习一下LCS的写法. 实现LCS的算法和算法导论上的方式基本一致,都是先建好两个表,一个存储在(i,j)处当前最长公共子序列长度,另一个存储在(i,j)处的回溯方向. 相对 ...

  3. 1.ASP.NET MVC使用EPPlus,导出数据到Excel中

    好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...

  4. MySQL基础知识和操作(一)

  5. jQuery Raty 星级评分

    在线实例 实例演示 使用方法 <div id="star"></div> 复制 $('#star').raty(); 复制 你只需要有一个 div构建Rat ...

  6. js基础(改变透明度实现轮播图的算法)

    前面有分享过改变层级的轮播图算法,今天继续利用透明度来实现无位移的轮播图算法. 实现逻辑:将所有要轮播的图片全部定位到一起,即一层一层摞起来,并且利用层级的属性调整正确的图片顺序,将图片的透明度全部设 ...

  7. Express 4 handlebars 不使用layout写法

    Express 4 handlebars 不使用layout写法 Express node nodejs handlebars layout 最近刚开始学习使用nodejs. 使用express搭建了 ...

  8. Resharper的配置和使用

    一:Reshaper简介 Reshaper是C#开发IDE工具Visual Studio的一款第三方插件,Reshaper让 VS 变得更强大.优势是:它提供了一些在 VS 基础上更方便于程序员开发的 ...

  9. React Native之坑总结(持续更新)

    React Native之坑总结(持续更新) Genymotion安装与启动 之前我用的是蓝叠(BlueStack)模拟器,跑RN程序也遇到了一些问题,都通过搜索引擎解决了,不过没有记录. 但是Blu ...

  10. ASP.NET MVC 5 01 - ASP.NET概述

    本篇目录: ASP.NET 概述 .NET Framework 与 ASP.NET ASP.NET MVC简介 ASP.NET的特色和优势 典型案例 ▁▃▅ ASP.NET概述 ▅▃▁ 目前开发B/S ...