浅谈CSC选择器和CSS权重

1、css的语法规则

  • 由css选择器(selector),以及一条或多条声明组成,用冒号分开
  • 举例:selector{porperty:value} 是key-value的方式

2.为什么会有选择器?

  • 选择器是匹配元素的一种模式,不止是在css中

3.基本的选择器

  • 元素选择器
<p>
color: red;
</p>
  • id选择器
<style>
#notification {
font-size: 14px;
}
</style>
<p id="notification"></p>
  • 类选择器
<style>
.first {
  font-weight: bold;
}
.done {
  text-decoration: line-through;
}
</style>
<ul>
  <li class="first done">起床</li>
  <li class="second done">刷牙</li>
  <li class="third">洗脸</li>
</ul>
  • 通用选择器
* {
  box-sizing: border-box;
}

.flex-container * {
  flex-basis: 100%;
}
  • 属性选择器
    [attr]
    [attr] 选择包含 attr 属性的所有元素,不论 attr 的值为何。
[disabled] {
  cursor: not-allowed;
}

[attr=val]

[attr=val] 仅选择 attr 属性被赋值为 val 的所有元素。

[data-color="gray"] {
  color: #ccc;
}

[attr~=val]
[attr~=val] 仅选择 attr 属性的值(以空格间隔出多个值)中有包含 val 值的所有元素,比如位于被空格分隔的多个类(class)中的一个类。
[attr=val]
[attr
=val] 选择 attr 属性的值中包含字符串 val 的元素。

[title*="fuck"] {
  display: none;
}

[attr^=val]

[href^="http://"] {
  background-color: #f0ad4e;
}

[attr$=val]

[attr$=val] 选择 attr 属性的值以 val 结尾(包括val)的元素。

[src$="gif"] {
  border: 1px solid #ccc;
}

[attr|=val]

[attr|=val] 选择 attr 属性的值以 val(包括val)或 val-开头的元素(-用来处理语言编码)。

[lang|="zh"] {
  font-family: '微软雅黑';
}
  • 伪类选择器
a:link { ... }
a:visited { ... }
a:hover { ... }
a:active { ... }
li:first-child { ... }
li:last-child { ... }
body :not(p) { ... }
p:not(.warning) { ... }
  • 为元素选择器
.clearfix::after {
  content: '';
  clear: both;
  display: block;
}
.happy::before {
  content: '😁';
}
p::selection {
  color: white;
  background: blue;
}
::backdrop 实验特性
::first-line 将样式只应用于一个块状元素的首行。
input::-webkit-input-placeholder {
  color: #aaa;
}

介绍完了CSS选择器,下面我们CSS权重问题

在介绍之前我们先来看一道题目

饥人谷三个字的最后的样式是?看完这道题 小编来给你叨一叨CSS的权重~

1、什么是CSS权重?

  • 权重决定了你CSS规则怎样被浏览器解析直到生效,即你的
    CSS规则是怎样显示的

2、权重之比

权重顺序:!important>内联>ID>类=伪类=属性>标签(元素)=伪元素> 通配符

怎么确定权重?有几句口诀来看看吧

  • 从0开始:
  • 一个行内样式+1000;
  • 一个id+100;
  • 一个属性/类/伪类+10;
  • 一个元素/伪元素+1;

举个栗子

p #cover . border a:havor
#cover--id选择器加了100
.border--class类选择器加了1;
最后的权重是: 0122

3.权重的基本规则

  • 1、相同的权重:最后面出现的选择器为最后规则
  • 2 不同的权值权重高则生效

4、对权重规则的总结一条样式规则的整体权重值包含四个独立部分:[A,B,C,D]

  • A表示内联样式,只要1或者0两个值
  • B表示规则中ID的数量
  • C表示规则中标签和伪元素以外的其他选择器数量
  • D表示规则中标签和伪元素的数量比较时从高位到低位(从A到D)分别比较,高位相同才需要比较低位(从A到D)分别比较,高位相同才需要比较低位
  • important 注意点:
  • 如果多条规则中都对同一个属性指定了!important,这时候!important的作用相互抵消,依然按照ABCD四组计算比较
  • !important的作用只有在具有唯一性时才能提现,但是我们永远无法预料自己什么时候又需要覆盖一个已经指定了!important的属性,所以最好的办法就是不要使用。

5、CSS优先级法则

  • A)选择器都有一个权值,权值越大越优先
  • B)当权值相等时,后出现的样式表要优于先出现的样式设置
  • C)继承的CSS样式优先级低于低于指定的CSS样式
  • D)在同一组属性设置中标
    有“!important”规则的优先级最大

再回到之前的题目

msg:100
content 100 p 1 101
.container 10 box 10 p 1 22
p 1 #msg 101
第二行和第四行的权重相同,权重相同的情况下最后面出现的选择器为最后规则。
所以样式是:粉色,14px

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,012评论 4 359
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,589评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 106,819评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,652评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 51,954评论 3 285
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,381评论 1 210
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,687评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,404评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,082评论 1 238
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,355评论 2 241
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,880评论 1 255
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,249评论 2 250
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,864评论 3 232
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,007评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,760评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,394评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,281评论 2 259

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,625评论 1 92
  • 其实平时用得多的选择器无非也就是那么几个,时间久了,许多不常用的选择器就慢慢忘记了。为了不让自己忘记这些选择器,今...
    盛夏晚清风阅读 1,757评论 0 5
  • CSS选择器结构逻辑图 接下来按照结构逻辑图具体讲解各个选择器的作用及用法; 基本选择器 基本选择器主要有以下5类...
    FoolishFlyFox阅读 522评论 0 8
  • 引言 本人在慕课网学习HTML+CSS基础课程,记录一些文字,方便自己回忆,也希望对大家有所帮助 上次给大家带来了...
    zhaolion阅读 7,343评论 18 272
  • 今天怎么一个找我电话都没有,怎么这么消停,真无聊;明天事情好多呀,压得人都喘不过来气,真烦人;昨晚聚会喝酒说错话了...
    正本阅读 1,121评论 2 7