cari
Rumahhujung hadapan webhtml tutorial详解CSS中的选择器

详解CSS中的选择器

Jun 24, 2017 pm 01:38 PM
cssbelajarnotapemilih

1、通配符选择器

通配符选择器用“*"号表示,是所有选择器中作用范围最广的,能匹配页面中所有的元素

/*设置当前页面中所有标签的颜色为红色*/* {color: red;
}

2、标签选择器

标签选择器就是选择当前页面中相同名字的标签

/*设置所有p标签的文字颜色为红色*/p {color: red;
}

3、ID选择器

id选择器使用"#"进行标识,后面紧跟id名

{:;
}
<h1 id="title">这是标题</h1>

注意HTML标签中ID的属性值在一个页面中必须是唯一的(是W3C规范而不是硬性规则)。

ID选择器命名规范

  • 只允许出现字母(大小写均可,严格区分) 、下划线、数字,也就是说,id=”Head”和 id=”head”不冲突

  • 只允许以字母开头

  • 命名没有长度限制,可以是1个字母,也可以是很多个,不过不建议太长

  • 不允许出现标签名(不是硬性规定)

4、类选择器

类选择器就是选取页面中所有标签的class属性值相同的一类标签,用.(点)表示

{:;
}
<h1 class="head">这是标题1</h1><h2 class="head">这是标题2</h2>

一个标签可以包含多个类选择器,在class标签中用空格隔开。

.head {color: blue;
}.subHead {font-size: 50px;
}
<h2 class="head subHead">这是标题2</h2>

5、复合选择器

5.1、交集选择器

交集选择器又称标签指定式选择器,由两个选择器构成,其中第一个为标记选择器,第二个为class选择器或id选择器,两个选择器之间不能有空格,如

h3.special  /* 需要满足标签是h3同时拥有special类 */

p#one /* 需要满足标签是p同时id为one */

5.2、并集选择器

并集选择器是各个选择器通过逗号连接而成的,任何形式的选择器(包括标记选择器、class类选择器id选择器等),都可以作为并集选择器的一部分。如果某些选择器定义的样式完全相同,或部分相同,就可以利用并集选择器为它们定义相同的CSS样式

/*同时给标签h3与class为box的元素设置样式*/h3, .box {color: red;font-size: 14px;
}

5.3、后代选择器

后代选择器用来选择元素或元素组的后代,其写法就是把外层标记写在前面,内层标记写在后面,中间用空格分隔。当标记发生嵌套时,内层标记就成为外层标记的后代(后代不仅仅包括儿子,还包括子子孙孙)。

 1 <!DOCTYPE html> 2 <html lang="en"> 3     <head> 4         <meta charset="UTF-8"> 5         <title>Document</title> 6  7         <style type="text/css"> 8             .province li { 9                 color: red;10             }11         </style>12     </head>13     <body>14         <div class="province">15             <ul class="north">16                 <li>北京</li>17                 <li>河北</li>18                 <li>山西</li>19             </ul>20 21             <ul class="south">22                 <li>广东</li>23                 <li>海南</li>24                 <li>福建</li>25             </ul>26         </div>27     </body>28 </html>

页面显示效果

 

5.4、子代选择器

子代选择器与后代选择器的区别在于,子代选择器只选择儿子级别的元素

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>Document</title> 6  7     <style type="text/css"> 8         div > strong { 9             color: red;10         }11     </style>12 </head>13 <body>14     <div>15         <strong>直接子标签</strong>16         <span>17             <strong>间接子标签</strong>18         </span>19     </div>20 </body>21 </html>

页面显示效果

可以看到包裹在span标签中的文字颜色不变。

5.5、相邻选择器

h1 + p {margin-top:50px;}表示增加紧接在 h1 元素后出现的段落的上边距。

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>相邻选择器</title> 6  7     <style type="text/css"> 8         li + li {font-weight:bold;} 9     </style>10 </head>11 <body>12     <div>13         <ul>14             <li>List item 1</li>15             <li>List item 2</li>16             <li>List item 3</li>17           </ul>18           <ol>19             <li>List item 1</li>20             <li>List item 2</li>21             <li>List item 3</li>22           </ol>23     </div>24 </body>25 </html>

浏览器运行结果:

li+li选择的是第二个li,同理也可以理解成紧跟着第二个li的兄弟,即是第三个li,当然是在同一个级别下。

6、属性选择器

属性选择器就是根据html标签的属性进行过滤选择

6.1、简单属性选择

格式:标签名[属性名称1][属性名称2][...]{样式...},属性名称可以一个到多个

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>简单属性选择</title> 6  7     <style type="text/css"> 8         /*选择具有class属性的div*/ 9         div[class] {10             color: red;11         }12         13         /*选择同时具有id属性与class属性的div*/14         div[id][class] {15             background-color: green;16         }17     </style>18 </head>19 <body>20     <div>普通div</div>21     <div class="box">有class属性的div</div>22     <div id="box" class="box">同时具有id属性与class属性的div</div>23 </body>24 </html>

6.2、属性值选择

格式:标签名[属性="属性值"]{样式...},同样的,属性="属性值"可以有多个

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>属性值选择</title> 6  7     <style type="text/css"> 8         /*选择class=box的div*/ 9         div[class="box"] {10             color: green;11         }12         13         /*选择id="box",同时class="box"的div*/14         div[id="box"][class="box"] {15             background-color: pink;16         }17     </style>18 </head>19 <body>20     <div>普通div</div>21     <div class="box">有class属性的div</div>22     <div id="box" class="box">同时具有id属性与class属性的div</div>23 </body>24 </html>

6.3、属性名全包含

格式:标签名[属性名~="属性值"]{样式...},选取属性名中包含属性值的标签,同样的,属性名~="属性值"可以有多个

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>属性名全包含</title> 6  7     <style type="text/css"> 8         /*选择class属性包含box的div*/ 9         div[class~="box"] {10             font-size: 30px;11             color: green;12         }13         14         /*选择id属性包含box,同时class属性包含content的div*/15         div[id~="box"][class~="content"] {16             background-color: red;17         }18     </style>19 </head>20 <body>21     <div class="content">普通div</div>22     <div class="box">class属性包含box的div</div>23     <div id="box head" class="content">id属性包含box,同时class属性包含content的div</div>24 </body>25 </html>

可以看到属性名~="属性值"只要值中有一个包含就符合条件了

6.4、属性模糊选择

格式:属性模糊选择有两种格式,分别为

标签名[属性^="属性值"]{样式...},如div[id^="box"],表示选择具有id属性且属性值为以box开头的字符串的div元素;

标签名[属性$="属性值"]{样式...},如div[id$="box"],表示选择具有id属性且属性值为以box结尾的字符串的div元素。

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>属性模糊选择</title> 6  7     <style type="text/css"> 8         /*选择class属性以box开头的div*/ 9         div[class^="box"] {10             font-size: 30px;11             color: blue;12         }13         14         /*选择class属性以content结尾的div*/15         div[class$="content"] {16             background-color: purple;17         }18     </style>19 </head>20 <body>21     <div>普通div</div>22     <div class="boxer">class属性以box开头的div</div>23     <div class="maincontent">class属性以content结尾的div</div>24 </body>25 </html>

6.5、属性模糊匹配包含

格式:标签名[属性*="属性值"]{样式...},与属性名全包含不同的是,*表示只要包含就可以,如div[id*="box"]表示id属性包含box的div标签

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>属性模糊匹配包含</title> 6  7     <style type="text/css"> 8         /*选择class属性包含box的div*/ 9         div[class*="box"] {10             font-size: 30px;11             color: green;12         }13     </style>14 </head>15 <body>16     <div class="content">普通div</div>17     <div class="smallboxcon">class属性包含box的div</div>18     <div class="box">class属性包含box的div</div>19 </body>20 </html>

7、伪类选择器

CSS 伪类用于向某些选择器添加特殊的效果

:link

应用于未被访问过的链接。IE6不兼容,解决此问题,直接使用a标签。

:visited

应用于已经被访问过的链接

:hover

应用于有鼠标指针悬停于其上的元素。在IE6只能应用于a连接,IE7+所有元素都兼容。

:active

应用于被激活的元素,如被点击的链接、被按下的按钮等。

:focus

应用于拥有键盘输入焦点的元素。

 

 

 

 

 

 

 

以a标签为例

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>伪类</title> 6     <style> 7         a:link { 8             color: red; 9         }10 11         a:visited {12             color: green;13         }14 15         a:hover {16             background-color: blue;17         }18 19         a:active {20             background-color: yellow;21         }22 23         a:focus {24             font-size: 30px;25         }26     </style>27 </head>28 <body>29     <a href="#">伪类的应用链接</a>30 </body>31 </html>

注意伪类的书写顺序为:link,:visited,:hover,:active,否则有可能会达不到预期的效果。

如果需要重复测试效果,需要清除浏览器缓存。

8、伪元素选择器

CSS 伪元素用于向某些选择器设置特殊效果。

8.1、:first-line 伪元素

"first-line" 伪元素用于向文本的首行设置特殊样式。注意"first-line" 伪元素只能用于块级元素,下面的属性可应用于 "first-line" 伪元素:font、color、background、word-spacing、  letter-spacing、text-decoration、vertical-align、text-transform、line-height、clear

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS伪元素first-line</title> 6  7     <style type="text/css"> 8         p:first-line { 9             color:#ff0000;10             font-size:xx-large;11         }12     </style>13 </head>14 <body>15     <p>16         这是一个段落这是一个段落这是一个段落17         这是一个段落这是一个段落这是一个段落18         这是一个段落这是一个段落这是一个段落19     </p>20 </body>21 </html>

8.2、:first-letter 伪元素

"first-letter" 伪元素用于向文本的首字母设置特殊样式。注意"first-letter" 伪元素只能用于块级元素。下面的属性可应用于 "first-letter" 伪元素:font、color、background、margin、   padding、border、text-decoration、vertical-align (仅当 float 为 none 时)、text-transform、line-height、float、clear

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS伪元素first-letter</title> 6     <style type="text/css"> 7         p:first-letter { 8             color:#ff0000; 9             font-size:xx-large;10         }11     </style>12 </head>13 <body>14     <p>15         这是一个段落这是一个段落这是一个段落16         这是一个段落这是一个段落这是一个段落17         这是一个段落这是一个段落这是一个段落18     </p>19 </body>20 </html>

8.3、:before 伪元素

":before" 伪元素可以在元素的内容前面插入新内容,一般配合content使用

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS伪元素before</title> 6     <style type="text/css"> 7         p:before { 8             content:"@@@"; 9         }10     </style>11 </head>12 <body>13     <p>14         这是一个段落这是一个段落这是一个段落15         这是一个段落这是一个段落这是一个段落16         这是一个段落这是一个段落这是一个段落17     </p>18 </body>19 </html>

8.4、:after 伪元素

与:before伪元素相反,":after" 伪元素可以在元素的内容之后插入新内容

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS伪元素after</title> 6     <style type="text/css"> 7         p:after { 8             content:"@@@"; 9         }10     </style>11 </head>12 <body>13     <p>14         这是一个段落这是一个段落这是一个段落15         这是一个段落这是一个段落这是一个段落16         这是一个段落这是一个段落这是一个段落17     </p>18 </body>19 </html>

8.5、伪元素和 CSS 类

伪元素可以与 CSS 类配合使用

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS伪元素和CSS类的结合</title> 6     <style type="text/css"> 7         p.artical:first-letter { 8             color:#ff0000; 9             font-size:xx-large;10         }11     </style>12 </head>13 <body>14     <p>15         这是一个段落这是一个段落这是一个段落16         这是一个段落这是一个段落这是一个段落17         这是一个段落这是一个段落这是一个段落18     </p>19     <p class="artical">20         这是一个段落这是一个段落这是一个段落21         这是一个段落这是一个段落这是一个段落22         这是一个段落这是一个段落这是一个段落23     </p>24 </body>25 </html>

8.6、多重伪元素

可以结合多个伪元素来使用

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4     <meta charset="UTF-8"> 5     <title>CSS多重伪元素</title> 6  7     <style type="text/css"> 8         p:first-letter { 9             color:#ff0000;10             font-size:xx-large;11         }12 13         p:first-line {14             color:#0000ff;15         }16     </style>17 </head>18 <body>19     <p>20         这是一个段落这是一个段落这是一个段落21         这是一个段落这是一个段落这是一个段落22         这是一个段落这是一个段落这是一个段落23     </p>24 </body>25 </html>

 

Atas ialah kandungan terperinci 详解CSS中的选择器. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Memahami HTML, CSS, dan JavaScript: Panduan PemulaMemahami HTML, CSS, dan JavaScript: Panduan PemulaApr 12, 2025 am 12:02 AM

WebDevelopmentReliesOnhtml, CSS, andjavascript: 1) HtmlStructuresContent, 2) CSSStylesit, dan3) JavaScriptaddsInteractivity, Formingthebasisofmodernwebexperiences.

Peranan HTML: Penstrukturan Kandungan WebPeranan HTML: Penstrukturan Kandungan WebApr 11, 2025 am 12:12 AM

Peranan HTML adalah untuk menentukan struktur dan kandungan laman web melalui tag dan atribut. 1. HTML menganjurkan kandungan melalui tag seperti, menjadikannya mudah dibaca dan difahami. 2. Gunakan tag semantik seperti, dan lain -lain untuk meningkatkan kebolehcapaian dan SEO. 3. Mengoptimumkan kod HTML boleh meningkatkan kelajuan pemuatan laman web dan pengalaman pengguna.

HTML dan Kod: Melihat lebih dekat pada istilahHTML dan Kod: Melihat lebih dekat pada istilahApr 10, 2025 am 09:28 AM

Htmlisaspecifictypeofcodefocusedonstructuringwebcontent, manakala "kod" secara meluas ini

HTML, CSS, dan JavaScript: Alat penting untuk pemaju webHTML, CSS, dan JavaScript: Alat penting untuk pemaju webApr 09, 2025 am 12:12 AM

HTML, CSS dan JavaScript adalah tiga tiang pembangunan web. 1. HTML mentakrifkan struktur laman web dan menggunakan tag seperti, dan sebagainya. 2. CSS mengawal gaya laman web, menggunakan pemilih dan atribut seperti warna, saiz font, dan lain-lain.

Peranan HTML, CSS, dan JavaScript: Tanggungjawab TerasPeranan HTML, CSS, dan JavaScript: Tanggungjawab TerasApr 08, 2025 pm 07:05 PM

HTML mentakrifkan struktur web, CSS bertanggungjawab untuk gaya dan susun atur, dan JavaScript memberikan interaksi dinamik. Ketiga melaksanakan tugas mereka dalam pembangunan web dan bersama -sama membina laman web yang berwarna -warni.

Adakah HTML mudah belajar untuk pemula?Adakah HTML mudah belajar untuk pemula?Apr 07, 2025 am 12:11 AM

HTML sesuai untuk pemula kerana mudah dan mudah dipelajari dan dapat melihat hasilnya dengan cepat. 1) Keluk pembelajaran HTML adalah lancar dan mudah dimulakan. 2) Hanya menguasai tag asas untuk mula membuat laman web. 3) Fleksibiliti yang tinggi dan boleh digunakan dalam kombinasi dengan CSS dan JavaScript. 4) Sumber pembelajaran yang kaya dan alat moden menyokong proses pembelajaran.

Apakah contoh tag permulaan dalam html?Apakah contoh tag permulaan dalam html?Apr 06, 2025 am 12:04 AM

Anexampleofastartartingtaginhtmlis, yangbeginsaparagraph.startingtagsareessentialinhtmlasttheyinitiateelements, definetheirtypes, andarecrucialforstructuringwebpagesandconstructionthedom.

Bagaimana cara menggunakan susun atur flexbox CSS untuk mencapai penjajaran yang berpusat pada kesan segmentasi garis putus -putus dalam menu?Bagaimana cara menggunakan susun atur flexbox CSS untuk mencapai penjajaran yang berpusat pada kesan segmentasi garis putus -putus dalam menu?Apr 05, 2025 pm 01:24 PM

Bagaimana untuk merancang kesan segmentasi garis bertitik di menu? Semasa merancang menu, biasanya tidak sukar untuk menyelaraskan kiri dan kanan antara nama hidangan dan harga, tetapi bagaimana pula dengan garis bertitik atau titik di tengah ...

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.