我们知道,firefox在众多浏览器中是对css 2高度兼容的一款浏览器,那是我能够编写一个中型b2b网站的时候(并不能说是我遇到过的难题)在禅意花园中看到的一个案例,说的是某个菜单在css中定义了以后只能在firefox中正常显示。因为那个css涉及的滤镜太多,而且还有css中"级联(cascade)"这种强大功能的支持。

那么级联样式表css中的"级联"到底是什么意思呢?W3C是这样来描述的:css级联为每个样式规则指派权重,若元素应用了多个样式规则,那么将优先使用权重最高的的样式。

听说搜索引擎对某个网站的赋予的权重比较高或比较低,但是css中的"级联"赋予的权重是什么呢?W3C的这段定义,看上去很富有深意,但是它只包含了两个信息传递给了我们,那就是---特殊性和继承性。这两个概念将会成为我们学习的良师益友。当然,凡事都是两面的,也有可能成为我们的噩梦!接下来我们就来着重来说一下这个级联能够对我们书写带来些什么!

级联概括了两个概念---特殊性和继承性,下面我们开始说一下这个继承性,继承性也就是你定义一个样式这个样式可以运用到它的子孙子元素,当然,不一定要都运用一个样式,也可以赋予几个选择器中的几个不同样式。我们线看下代码:

1 .box
2 {
3     /*定义了一个样式这个样式将会运用到里面元素的h1,h2,h3,h4,p,ul,li等子孙元素*/
4     color:red;              
5 }

再来看段代码:

01 .box
02 {
03     /*box运用了一个样式,它的子孙要默认这个样式,这就是继承*/
04     color:red;          
05 }
06 .box .archive
07 {
08     /*但是拥有.archive这个选择器的标签不老实,他不用老祖宗的东西,自己创造了个green的样式来,这样权重提高了,他就可以不用继承了*/
09     color:green;        
10 }

这样的话大家大概能弄明白这个继承的含义了?如果我们每次都要定义一个样式,每个写一个选择器,累死人,不可想象有多大的工作量。

下面我们来看下这个特殊性有什么魅力。

前面我们已经来看到了两个例子,我们应该也能从中读到些什么吧,首先我们看到后面的规则比前面的权重高,比较特殊一点,尽管特殊性的例子看着比较简单,但是它本身存在的问题可不少。我们完全可能不经意的时候创造出了特殊过分了的样式规则,如果想要解决,我们需要想出更特殊的样式规则!在看代码(有代码有真相):

01 body>html #head ul.navigation li.home a
02 {
03     /*本来这个就可以命令a的元素样式为红色,鼠标移动过也是一样,但我们想让它移动过去有变化怎么办?*/
04     color:red;         
05 }
06 body>html #head ul.navigation li.home a:hover
07 {
08     /*ok这段代码解决了,这就是特殊中的特殊,来继承已经不能控制我了,哈哈*/
09     color:green;       
10 }

控制特殊性:我们看到上面的是不是太特殊了?有点过分复杂?没关系,我们接下来再来个代码真相。

01 #linklist ul li h3
02 {
03     /*虽然标准,但是还是有些别扭*/
04     color:red;          
05 }
06 #linklist h3
07 {
08     /*看我比较渐变吧,轻装上阵*/
09     color:red;          
10 }

上面的例子表明了我们不能一层一层的来做无用功,有时候甚至对浏览器的解析也是一种负担。写了很多额外的选择器,却没有得到应有的评价。

从理论上来说,CSS规则的权重高低问题取决于CSS选择符优先级的的计算结果。CSS行内样式与各种选择符都可以采用某一个数值来表示:

  • 行内样式(即直接在结构中给元素style属性)为:1000
  • ID选择符为:0100
  • 类选择符、每个属性选择符(形如[attr=value]等)、每个伪类(形如:hover等):0010
  • 类型选择符(即标签元素或伪元素)为:0001
  • 其它选择符包括全局选择符*,加0000。相当于没加,不过这也是一种specificity

某一样式权重的最终确立取决于各选择器相加的结果,如:

1 选择符 特性值
2 h1 {color:blue;}     1
3 p em {color:purple;}     1+1=2
4 .apple {color:red;}  10
5 p.bright {color:yellow;} 1+10=11
6 p.bright em.dark {color:brown;}  1+10+1+10=22
7 #id316 {color:yellow}    100

按这些规则将数字符串逐位相加,就得到最终的权重,然后在比较取舍时按照从左到右的顺序逐位比较。而CSS继承性的权重是非常低的,是比普通元素的权重还要低的0。因此形如body>html #head ul.navigation li.home a的选择器,要想实现子类继承其子类选择符权重值就不能低于其本身的权重值,同时这也加重了浏览器的负担,所以可以利用上面介绍的方法控制其特殊性。

CSS样式权重的级联cascade的概念的更多相关文章

  1. CSS特异性(CSS Specificity)的细节之CSS样式权重的计算与理解(CSS样式覆盖规则)

    本篇讲解CSS特异性(CSS Specificity)的细节,也就是CSS样式选择器的权重计算 通过计算选择器的权重(weight)最终决定哪个选择器将获得优先权去覆盖其他选择器的样式设定,即“优先原 ...

  2. 13 CSS样式权重问题

    <!-- 权重问题整体说明: 1.权重的意义:判定CSS属性的优先级高低,也就是说判定那个CSS的属性优先显示,将其他的低优先级的CSS样式覆盖掉. 2.如何判断权重:数选择器的数量,按照Id选 ...

  3. css样式权重优先级,css样式优先级

    原文:http://www.bkjia.com/Javascri... 样式选择器权重优先级: important > 内嵌样式 > ID > 类 > 标签 | 伪类 | 属性 ...

  4. 权重和层叠规则决定了CSS样式优先级

    一.基本的优先级规则 比较同一级别的个数,数量多的优先级高,如果相同即比较下一级别的个数,至于各级别的优先级如下: important > 内联 > ID > 类 > 标签 | ...

  5. 初识CSS样式表

    背景介绍: 接触了新闻公布系统,这也是自己第一个B/S的项目.从之前的拖拽空间.任意布局到现在的HTML总会有非常多的新奇.棘手和挑战.可是不管是何种形式都离不开主要的步骤:做前台.做后端.能够说一个 ...

  6. 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧

    记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...

  7. 一起学HTML基础-CSS样式表-基本概念、分类、选择器

    一.基本概念: CSS  (Cascading Style Sheets)层叠样式表,是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言. ...

  8. 11-19网页基础--第二部分CSS样式表基本概念

    CSS,全称(Cascading Style Sheets,层叠样式表),作用是美化HTML网页. 一.基本概念:是用于(增强)控制网页样式并允许将样式信息与网页内容分离的一种标记性语言. 你可能对C ...

  9. 从webkit内核简单看css样式和css规则优先级(权重)

    目录 webkit中样式相关类及类间关系 样式规则匹配 权重(优先级)计算 权重相同时的覆盖原则 webkit中样式相关类及类间关系 资料来源: <webkit技术内幕> 结构相关类: 1 ...

随机推荐

  1. Hadoop(13)-MapReduce框架原理--Job提交源码和切片源码解析

    1.MapReduce的数据流 1) Input -> Mapper阶段 这一阶段的主要分工就是将文件切片和把文件转成K,V对 输入源是一个文件,经过InputFormat之后,到了Mapper ...

  2. python系列7进程线程和协程

    目录 进程 线程 协程  上下文切换 前言:线程和进程的关系图 由下图可知,在每个应用程序执行的过程中,都会去产生一个主进程和主线程来完成工作,当我们需要并发的执行的时候,就会通过主进程去生成一系列的 ...

  3. go学习笔记-运算符

    运算符 运算符 内置运算符 算术运算符 关系运算符 逻辑运算符 位运算符 赋值运算符 其他运算符 算术运算符 假定 A 值为 10,B 值为 20. 运算符 描述 实例 + 相加 A + B 输出结果 ...

  4. python2.7入门---Number(数字)

        今天咱们来简单分享一下关于python中的一种数据类型和操作方法.费话不多说哈,咱们直接来进行实践加理论.首先,我们要知道,Python Number 数据类型用于存储数.数据类型是不允许改变 ...

  5. 深度学习(deep learning)优化调参细节(trick)

    https://blog.csdn.net/h4565445654/article/details/70477979

  6. C#获取网络图片

    简单获取图片 string url = zhi_txt.Text;//图片地址 string dizhi = lujing.Text;//图片下载后保存路径及图片名称要写在一块 WebClient w ...

  7. CCF-NOIP-2018 提高组(复赛) 模拟试题(四)

    T1 贪吃蛇 [问题描述] 贪吃蛇是一个好玩的游戏.在本题中,你需要对这个游戏进行模拟. 这个游戏在一个 \(n\) 行 \(m\) 列的二维棋盘上进行. 我们用 \((x, y)\) 来表示第 \( ...

  8. python学习总结---网络编程

    网络编程 相关概念 - OSI七层模型:它从低到高分别是:物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. - TCP/IP: 在OSI七层模型基础上简化抽象出来的一套网络协议簇,现在得到 ...

  9. vs code 在终端下使用 code ./ 打开当前项目

    Mac OS Visual Studio Code的扩展工具菜单中有Install command line的快捷安装 运行 VS code并打开命令面板( ⇧⌘P ),然后输入 shell comm ...

  10. Linux 进程--父进程查询子进程的退出状态

    僵尸进程 当一个子进程先于父进程结束运行时,它与其父进程之间的关联还会保持到父进程也正常地结束运行,或者父进程调用了wait才告终止. 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程,它 ...