博客列表 >选择器的权重\伪类选择器

选择器的权重\伪类选择器

P粉355147598
P粉355147598原创
2022年03月22日 14:55:192254浏览

一、选择器的权重

1、权重的比例

将3种选择器分别看做权重的千位、百位、个位

  • id: 千位
  • class: 百位
  • tag: 个位
    在编辑器中降鼠标提留在选择器上也可以看到权重

2、权重计算实例

  • 标签
  1. <h1>选择器的权重</h1>
  1. h1 {
  2. color: pink;
  3. }

此时使用标签h1选中,id:0,class:0,tag:1,故权重计算=0,0,1。

  1. <h1 class="header">选择器的权重</h1>
  1. .header {
  2. color: red;
  3. }
  4. h1 {
  5. color: pink;
  6. }

h1的权重是(0,0,1)而.header的权重计算是(0,1,0),权重大的会覆盖权重小的,所以文字显示为红色。

  • id
  1. <h1 class="header" id="head">选择器的权重</h1>
  1. #head {
  2. color: gray;
  3. }
  4. .header {
  5. color: red;
  6. }
  7. h1 {
  8. color: pink;
  9. }

id选择器的权重是(1,0,0),比类和标签都大,所以显示灰色(由于id选择器的权重过大,在开发中一般不建议使用)。

3、权重的增加

如何在不使用id选择器的情况下,使权重高于类选择器?

  1. <h1 class="header" id="head">选择器的权重</h1>
  1. .header {
  2. color: red;
  3. }
  4. h1.header {
  5. color: pink;
  6. }

只要在标签选择器后面加上类,这样计算权重就=(0,1,1)>(0,1,0),文字的颜色就会变回粉色(其他增加权重的方法类似)。

4、关键词

在权重的计算中,如果在属性后面加上!important,那么会优先显示该条属性,而后再依据权重显示。

  1. <h1 class="header" id="head">选择器的权重</h1>
  1. #head {
  2. color: gray;
  3. }
  4. h1 {
  5. color: red !important;
  6. }

二、伪类选择器

1、伪类选择器选择子元素

  • 选择第一个子元素
    1. .list>li:first-of-type {
    2. background-color: pink;
    3. }

  • 选择最后一个子元素
    1. .list>li:last-of-type {
    2. background-color: pink;
    3. }

  • 选择第n个子元素
  1. .list>li:nth-of-type(4) {
  2. background-color: pink;
  3. }

  • 选择倒数第n个元素
  1. .list>li:nth-last-of-type(4) {
  2. background-color: pink;
  3. }

2、参数计算过程

  • 计算方法
  1. :nth-of-type(an+b)
  2. 1. a: 系数, [0,1,2,...]
  3. 2. n: [0,1,2,3,....]
  4. 3. b: 偏移量, 0开始
  5. 注: 计算出来的索引,必须是有效, 1开始
  • 实例计算

    1. .list> :nth-of-type(-n + 3) {
    2. background-color: lightgreen;
    3. }

计算过程:(-1x0 + 3 = 3;-1x1 + 3 = 3-1 = 2;-1x2 + 3 = 3-2 = 1;-1x3 + 3 = 3-3 = 0)

  • 奇数、偶数行的选择
  1. .list> :nth-of-type(odd) {
  2. background-color: lightgreen;
  3. }
  4. .list> :nth-of-type(even) {
  5. background-color: lightgreen;
  6. }

odd为奇数, even为偶数。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议