侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

CSS样式权重的级联cascade的概念深入理解

前端  /  管理员 发布于 7年前   203

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

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

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

复制代码代码如下:
.box
{
/*定义了一个样式这个样式将会运用到里面元素的h1,h2,h3,h4,p,ul,li等子孙元素*/
color:red;
}

再来看段代码:

复制代码代码如下:
.box
{
/*box运用了一个样式,它的子孙要默认这个样式,这就是继承*/
color:red;
}
.box .archive
{
/*但是拥有.archive这个选择器的标签不老实,他不用老祖宗的东西,自己创造了个green的样式来,这样权重提高了,他就可以不用继承了*/
color:green;
}

这样的话大家大概能弄明白这个继承的含义了?如果我们每次都要定义一个样式,每个写一个选择器,累死人,不可想象有多大的工作量。
下面我们来看下这个特殊性有什么魅力。
前面我们已经来看到了两个例子,我们应该也能从中读到些什么吧,首先我们看到后面的规则比前面的权重高,比较特殊一点,尽管特殊性的例子看着比较简单,但是它本身存在的问题可不少。我们完全可能不经意的时候创造出了特殊过分了的样式规则,如果想要解决,我们需要想出更特殊的样式规则!在看代码(有代码有真相):

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

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

复制代码代码如下:
#linklist ul li h3
{
/*虽然标准,但是还是有些别扭*/
color:red;
}
#linklist h3
{
/*看我比较渐变吧,轻装上阵*/
color:red;
}

上面的例子表明了我们不能一层一层的来做无用功,有时候甚至对浏览器的解析也是一种负担。写了很多额外的选择器,却没有得到应有的评价。
从理论上来说,CSS规则的权重高低问题取决于CSS选择符优先级的的计算结果。CSS行内样式与各种选择符都可以采用某一个数值来表示:
行内样式(即直接在结构中给元素style属性)为:1000
ID选择符为:0100
类选择符、每个属性选择符(形如[attr=value]等)、每个伪类(形如:hover等):0010
类型选择符(即标签元素或伪元素)为:0001
其它选择符包括全局选择符*,加0000。相当于没加,不过这也是一种specificity
某一样式权重的最终确立取决于各选择器相加的结果,如:
选择符 特性值
h1 {color:blue;} 1
p em {color:purple;} 1+1=2
.apple {color:red;} 10
p.bright {color:yellow;} 1+10=11
p.bright em.dark {color:brown;} 1+10+1+10=22
#id316 {color:yellow} 100
按这些规则将数字符串逐位相加,就得到最终的权重,然后在比较取舍时按照从左到右的顺序逐位比较。而CSS继承性的权重是非常低的,是比普通元素的权重还要低的0。因此形如body>html #head ul.navigation li.home a的选择器,要想实现子类继承其子类选择符权重值就不能低于其本身的权重值,同时这也加重了浏览器的负担,所以可以利用上面介绍的方法控制其特殊性。


  • 上一条:
    CSS中a标签样式的爱恨原则:定义链接样式的四个伪类
    下一条:
    CSS实现圆形放大镜狙击镜效果 只有圆圈里的放大
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客