CSS后代選擇器、子元素選擇器、相鄰兄弟選擇器區別與詳解


派生選擇器用的很多,派生選擇器具體包括為后代選擇器、子元素選擇器、相鄰兄弟選擇器,我們來理解一下他們之間的具體用法與區別。

1、css后代選擇器
語法:h1 em {color:red;} 表示的是從h1開始里面包含的所有的em元素變成紅色,h1為祖先,其他的em都是后代,即選中后代,不管是兒子還是孫子,只要是都會被選中,為后代選擇器。
例如

復制代碼
<html>
<head>
<style type="text/css">
ul em {color:red; font-weight:bold;}
</style>
</head>

<body>
<ul>
<li>List item 1
<ol>
<li>List item 1-1</li>
<li>List item 1-2</li>
<li>List item 1-3
<ol>
<li>List item 1-3-1</li>
<li>List item <em>1-3-2</em></li>
<li>List item 1-3-3</li>
</ol>
</li>
<li>List item 1-4</li>
</ol>
</li>
<li>List item 2</li>
<li>List item 3</li>
</ul>
</body>
</html>
復制代碼

 

即,無論你在哪里,我都要選中你,因為你是我的后代。

 

經常看見css的后代選擇器是這樣的寫法:

div.class   和 .class div 的形式兩者的區別:

div.class  是選中的類名為class 的div元素,與直接使用類選擇器.class不同,因為可能有其他的元素使用了class類名,比如<p class=""></p>,就不會被div.class選中;

.class div 是后代選擇器的一種,表示選中 類名為class的元素包含的所有的div元素;

 

 

2、css子元素選擇器
語法:h1>em{color:red;} 表示的是從h1開始里面的第一層em元素變成紅色,h1為祖先,em為兒子,就像世襲制一樣,只能傳給兒子,孫子和其他堂親都不行,例如

復制代碼
<style type="text/css">
h1 > strong {color:red;}
</style>

<h1>This is <strong>very</strong> <strong>very</strong> important.</h1>
<h1>This is <em>really <strong>very</strong></em> important.</h1>
復制代碼

 

只有第一個h1會變色。

3、相鄰兄弟選擇器
語法:h1 + p {margin-top:50px;} 表示是“選擇緊接在 h1 元素后出現的段落,h1 和 p 元素擁有共同的父元素”這是官方的說法,理解的誤區在於這個加號,h1和p並不是同時被選中的,而是選擇的是h1緊跟着后面的p元素,是遞進的關系,例如:

復制代碼
<!DOCTYPE HTML>
<html>
<head>
<style type="text/css">
li + li {color:red;}
</style>
</head>

<body>
<div>
<ul>
<li>List item 1</li>
<li>List item 2</li>
<li>List item 3</li>
</ul>
<ol>
<li>List item 1</li>
<li>List item 2</li>
<li>List item 3</li>
</ol>
</div>
</body>
</html>
復制代碼

 


li+li選擇的是第二個li,同理也可以理解成緊跟着第二個li的兄弟,即是第三個li,當然是在同一個級別下。所以出現第二、三li被選中。

 

完整示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Selector</title>
    <style>
        ul>li>em {
            color: red;
            font-weight: bold;
        }
        h1+p{
            color:red;
        }
    </style>
</head>
<body>
    <ul>
        <li><em>List item 1</em> 
            <ol>
                <li>List item 1-1</li>
                <li><em>List item 1-2</em></li>
                <li>List item 1-3</li>
            </ol>
        </li>
        <li>
            <em>List item 2</em> 
        </li>
        <li>
            List item 3
        </li>
    </ul>
    <h1>H1</h1>
    <p>param</p>
    <h2>H2</h2>
</body>
</html>

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM