选择器

2021/12/27

# 状态选择

状态

属性 状态
link 无状态
hover 覆盖
active 鼠标按下去时
focus 光标聚焦
visited 已访问过(历史记录有这一条)
  • 注意:【:link】和【:visited】应该放在最上面,因为同时多种状态且属性冲突时,取最下面一种状态设置的属性

例:【:hover】时元素的【:link】属性依旧触发,所以【:hover】应该定义在【:link的下面】

<body>
    <a href="#a1" id="a">超链接</a>

    <div id="a1">锚点</div>
    <style>
        a:visited {
            background-color: yellow;
        }
        a:link {
            background-color: red;
        }
        a:hover {
            background-color: blue;
        }
        a:active {
            background-color:greenyellow;
        }
    </style>
    <script>a.addEventListener("click", e => e.preventDefault())</script>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

取消【input】元素选中时的边框






 
 
 



<body>
    <input type="text" id="input1">
    <input type="text" id="input2">

    <style>
        #input1:focus {
            outline: none;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10

# 关联选择器

选择器 选择元素
交集:【p标签】且【.left】 p.left
后代:【p标签】内的【.left】 p .left【空格分开】
并集:【p标签】和【.left】 p,.left
子代 p>.left
所有弟弟 p~.left
下一个弟弟 p+.left

交集/后代/并集

<body>
    <p class="left">
        p且left
        <span class="left">p的儿子 left</span>
    </p>
    
    <span class="left">p的兄弟 left</span>

    <style>
        /* 交集选择器,p 且 left */
        p.left {
            color: red;
        }

        /* 后代选择器,p 的后代 left */
        p .left {
            color: green;
        }

        /* 并集选择器,p 和 left */
        p,.left {
            background-color: rgb(253, 224, 162);
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

子代/兄弟




 
 
 
 
 
 
 
























<body>
    <div class="big-brother">哥哥</div>
    
    <div class="me"><div class="child">
            儿子
            <div>孙子</div>
        </div>
    </div>
    
    <div class="brother">弟弟</div>

    <div class="sister">妹妹</div>


    <style>
        /* 下一个弟弟 */
        .me+div{
            background-color: red;
        }

        /* 所有弟弟 */
        .me~div {
            font-size: 25px;
        }

        /* 儿子 */
        .me>div {
            border: #333 solid 1px;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33

# 属性选择器

属性选择器

  • 元素拥有某个属性时选择,【css scope原理】
[property] {}
1
<body>
    <div>tag选择器</div>
    <div class="box">普通class选择器</div>
    <div class="box" data-hash123>class配属性选择器</div>


    <style>
        div {
            background-color: red;
        }
        .box {
            background-color: yellow;
        }
        .box[data-hash123] {
            background-color: green;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

# 正则属性选择器

正则匹配属性

选择器 含义
[id^=my] id以my开头
[data$=box] data以box结尾
[id*=container] id包含container
<body>
    <div id="my-box">1</div>
    <div id="his-box">2</div>
    <div id="our-container">3</div>
    <div id="my-container">4</div>


    <style>
        div[id^=my] {
            background-color: red;
        }

        div[id$=container] {
            font-size: 40px;
        }

        div[id*=our] {
            color: pink;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

# 结构化伪类选择器

伪类

选择元素 选择器
非选择器 li:not(.me)
独子 container:only-child
大儿子 :first-child
小儿子 :last-child
按序选择 :nth-child(3) / :nth-child(2N)
奇偶选择器 :nth-of-type(even) / :nth-of-type(odd)
空选择器 :empty
跳转目标选择器 :target
选择器













 





<body>
    <ul class="father">
        <li class="big-brother">哥哥</li>
        <li class="me"></li>
        <li class="brother">弟弟</li>
        <li class="sister">妹妹</li>
    </ul>

    <ul class="father">
        <li>独子</li>
    </ul>

    <style>
        li:only-child {
            background-color: pink;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18

本选择器且【没有内容和子标签】

选择器










 
 









<body>
    <ul class="father">
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li>4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
        <li>8</li>
        <li><span></span></li>
        <li></li>
    </ul>

    <style>
        li:empty {
            background-color: pink;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

# 伪元素

伪元素

  • 伪元素:是一个附加至选择器末的关键词,允许你对被选择元素的特定部分修改样式。
  • 与伪类的区别:CSS 伪类 是添加到选择器的关键字,指定要选择的元素的【特殊状态】。
伪元素 效果
after 选择器内末尾添加一个伪元素
before 选择器内开头添加一个伪元素
first-letter 块级元素的第一行的第一个字母
first-line 所选块级元素的第一行
marker 结构化标识符
placeholder 占位文本
selection 选中文本的样式自定义

after/before

<body>
    <p class="content">我是一段文章文章。。。</p>

    <style>
        .content::before {
            content: "hello~,";
            background-color: pink;
        }
        .content::after {
            content: "that is all~";
            background-color: yellow;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14












 
 
 



<body>
    <p class="content">
        我是一段文章文章。。。
        <br>
        我是第二行
    </p>

    <div class="content">
        我是一段文章文章。。。
    </div>

    <style>
        .content::first-letter {
            background-color: pink;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17

marker: HTML默认的结构化标记增加自定义样式















 
 
 



<body>
    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
        <li class="me">4</li>
        <li>5</li>
        <li>6</li>
        <li>7</li>
        <li>8</li>
        <li>9</li>
        <li>10</li>
    </ul>
    <style>
        .me::marker {
            color: red;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19

placeholder:HTML默认的结构化标记增加自定义样式





 
 
 
 



<body>
    <input type="text" placeholder="默认占位符样式">
    <input type="text" class="mybox" placeholder="自定义占位符样式">
    <style>
        .mybox::placeholder {
            color: red;
            font-size: .7rem;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9
10

selection:自定义选中样式

<body>
    <p>我是文字我是文字我是文字</p>
    <div>我是文字我是文字我是文字</div>
    <style>
        p::selection {
            color: hotpink;
        }
    </style>
</body>
1
2
3
4
5
6
7
8
9

# 特殊技巧

  • input框的空选择器
  • input框不能用:empty判断空
input:not(:placeholder-shown) {}
1
上次更新: 11/1/2024