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

派生選擇器用的不少,派生選擇器具體包括爲後代選擇器、子元素選擇器、相鄰兄弟選擇器,咱們來理解一下他們之間的具體用法與區別。css

一、css後代選擇器
語法:h1 em {color:red;} 表示的是從h1開始裏面包含的全部的em元素變成紅色,h1爲祖先,其餘的em都是後代,即選中後代,無論是兒子仍是孫子,只要是都會被選中,爲後代選擇器。
例如html

<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>

運行結果:spa

即,不管你在哪裏,我都要選中你,由於你是個人後代。3d

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

<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>

運行結果:htm

只有第一個h1會變色。blog

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

<!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>

運行的結果是這樣的:class


li+li選擇的是第二個li,同理也能夠理解成緊跟着第二個li的兄弟,便是第三個li,固然是在同一個級別下。因此出現第2、三li被選中。import

相關文章
相關標籤/搜索