Heim >Web-Frontend >CSS-Tutorial >Dinge über CSS-Selektoren

Dinge über CSS-Selektoren

高洛峰
高洛峰Original
2016-11-24 13:19:471664Durchsuche

Bevor wir den CSS-Selektor vorstellen, lernen wir zunächst CSS kennen

CSS – Cascading Style Sheets werden als Artefakt für das Webseitenlayout von Web-Front-End-Wissenschaftlern ständig gelobt. . .

Lassen Sie uns das als nächstes besprechen. .

1. Eigenschaften von CSS

Nachteile des HTML-Schriftsatzes:

Umständlich einzurichten, mühsam zu ändern und gravierend mangelhaft an Funktionen.   

Vorteile des CSS-Stilsatzes:  

Die Satzattributfunktion ist vollständig, die Satzdatei kann unabhängig existieren und die Satzdatei kann gemeinsam genutzt werden

Klassifizierung des CSS-Stilsatzes:  

Inline-Satzstil, eingebetteter Satzstil, Satz externer Links

2. CSS-Satzstil

Inline-Satzstil:

Format: 2ff82cca2ae67a750cb63f8a5de431fb…e702308a6937582591eb19792cbdbd02

Beispiel:d06fab8a081b0398a4d8da78eaf02d39Satzstil< ;/p>

Inline-Satzstil:

Alle Stildefinitionen im Inline-Satz müssen zwischen c9ccee2e6ea535a969eb3f532ad9fe89..531ac245ce3e4fe3d50054a55f265927 und c9ccee2e6ea535a969eb3f532ad9fe89 liegen. ..531ac245ce3e4fe3d50054a55f265927 muss zwischen 93f0f5c25f18dab9d176bd4f6de5d30e..9c3bca370b5104690d9ef395f2c5f8d1 liegen und seine Funktionen können in drei Typen unterteilt werden:

1. Tag-Definitionstyp

2. Klassendefinitionstyp

3.id-Definitionstyp

Tag-Definitionstypformat:

Ende der Einführung in den CSS-Layoutstil danach. . . . Werfen wir als nächstes einen Blick auf die leistungsstarken Selektoren in CSS
<head>
 
  <style type=”text/css”>   
 
    标记名称{属性 1:属性值 1;属性 2:属性值 2;}   
 
    标记名称{属性 1:属性值 2;属性 2:属性值 2;}
 
  </style>
 
</head>
 
<body>
 
  <标记名称>…</标记名称>
 
</body>
 
class 定义型格式:
 
<head>
 
  <style type=”text/css”>   
 
    .定义名称{属性 1:属性值 1;属性 2:属性值 2;}   
 
    .定义名称 1,.定义名称 2{属性 1:属性值 1;属性 2:属性值 2;}
 
  </style>
 
</head>
 
<body>   
 
  <标记名称 class=”定义名称”>…</标记名称>
 
</body>
 
id 定义型格式:
 
<head>
 
  <style>   
 
    #定义名称{属性 1:属性值 1;属性 2:属性值 2;}   
 
    #定义名称 1,#定义名称 2{属性 1:属性值 1;属性 2:属性值 2;}
 
  </style>
 
</head>
 
<body>   
 
  <标记名称 id=”定义名称”>…</标记名称>
 
</body>
 
外部排版样式定义:
 
独立的样式排版:   
 
标记名称{属性 1:属性值 1;属性 2:属性值 2;}   
 
.定义名称{属性 1:属性值 1;属性 2:属性值 2;}
 
在<head>…</head>之间使用<link> 格式:
 
<head>   
 
  <link rel=”stylesheet” type=”text/css” href="http://www.php1.cn/">
 
</head>
 
在<head>…</head>之间使用 import 格式:
 
<head>
 
  <style type="text/css">
 
    @import "style.css"
 
  </style>
 
</head>

1 🎜>

2. Elementselektor

*{
 
font-size:13px;
 
font-family:"微软雅黑","华文楷体";
 
}

3. ID und Klasse

p,h1,h2,h3,a{
 
font-size:13px;
 
}

Selektoren werden zur Steuerung verwendet Stil des Seitendesigns. Viele Entwickler verwechseln IDs oft mit Klassen oder können diese beiden Selektoren einfach nicht richtig verwenden ist extrem falsch.

(1). Jede ID befindet sich auf einer Seite. Sie kann nur einmal als eindeutige Kennung verwendet werden für ein Element. Im Allgemeinen wird die ID nur für eindeutige Elemente der Seite verwendet, wie z. B. Kopfzeilen, Hauptnavigationsleisten, Layoutblöcke usw.

Beispiel:a1926d7db1d226bc346d21774732604fDieser Absatz hat roten Text.94b3e26ee717c64999d7867364b1b4a3

Entsprechender CSS-Code:

#hightlight{ color:#FFFFFF ; }

(2) ID mit Selektor kombinieren

/* Geeignet für alle h2-Titel*/

h2{ color:#333; font-size:16px; }

/*Nur für Titel h2 title*/

h2#title { color:#eee; }

Entsprechender HTML-Code:

(3).Verwenden Sie Anlässe der ID

Für jede ID kann nur ein Element diesen Stil auf jeder Seite verwenden, daher sollte die ID für jede Seite eindeutig sein und nur einmal verwendet werden, werden nicht beibehalten ,

(4). Wenn dieselbe CSS-Regel an mehr als einer Stelle verwendet werden muss, sollten IDs nicht verwendet werden.

<h2>Title Of My Article</h2>
 
<h2 id=”title”>Title Of My Article</h2>

(5). Die Anwendungsklasse kann unbegrenzt oft verwendet werden, daher ist sie eine sehr flexible Möglichkeit, CSS anzuwenden.

< ;p class=“hightlight“> ;sein Absatz hat roten Text.94b3e26ee717c64999d7867364b1b4a3

Zugehöriger CSS-Code:

(6). und IDs Beispiel:

Entsprechender CSS-Code:

.hightlight {color:FFFFFF; }
Entsprechender HTML-Code:

<ul id=”drinks”>
 
  <li class=”mix”>Beer</li>
 
  <li class=”mix”>Spirtis</li>
 
  <li class=”hot”>Cola</li>
 
  <li class=”hot”>Lemonade</li>
 
</ul>
(8). Verknüpfen Sie die Klasse direkt mit dem Element

p.bleached {color:red }

Entsprechender HTML-Code:
ul#drinks { color:FF6600; }
 
.mix { Color:#999999; }
 
.hot { Color:#333333; }
 
(7).利用类改写基本样式:
 
p{Color:#ff6600; }
 
.bleached {Color:#ccc; }

(9) Wenn die Klasse mehrmals wiederverwendet wird oder einen Unterklassenselektor verwendet, wählen Sie die Klasse aus. B. Layout, und verwenden Sie dann die ID.
<p>This paragraph has red text.</p>
 
<p class=”bleached”>This paragraph has red text.</p>

4. Kaskadierung von externen Links

6dc64a8ede33c8387f23752fc7fc69ab

80275508711500342eaae7a24c4a397b

<p class=”bleached”>This paragraph has red text.</p>
98349952b935a93b35aeaf8c2b5a0ffe

(2). Stile importieren, um Kaskadierung zu erreichen

@import url( "one.css")

@import url("two.css")

@import url(" three.css ")

Hinweis: Eine Regel muss beachtet werden. Je später die Regel gegeben wird, desto wichtiger ist sie.

5 . Gruppierung

6. Kontextauswahl

>

8. Unterklassenselektor

9. Andere Selektoren

(1). >

p{color:black;}

a{text-decoration:underline;}

h1{font -weight:bold ;}
h1{
 
  Font-family:隶书,宋体,楷体;   
 
  Line-height: 140%;   
 
  Color:#333;
 
}
 
h2{   
 
  Font-family:隶书,宋体,楷体;   
 
  Line-height: 140%;   
 
  Color:#333;
 
}
 
h3{   
 
  Font-family:隶书,宋体,楷体;   
 
  Line-height: 140%;   
 
  Color:#333;
 
}
 
/*分组后*/
 
h1,h2.h3{   
 
  Font-family:隶书,宋体,楷体;   
 
  Line-height: 140%;   
 
  Color:#333;
 
}
 
/*分组例外*/
 
h1{   
 
  Font-style:italic;
 
}

(2).

h1 { Color:#333; }
 
<h1>This is thegreatest heading <i>in the world</i></h1>
 
从 BODY 继承
 
Body {   
 
  Margin:10px;   
 
  Font-family:隶书;   
 
  Background:#000;   
 
  Color:#fff;
 
}
li a{text-decoration:none;}

#main h1{Color:red;}

 

(3).伪类

 

a:link{color:blue;}

 

a:visited{color:green;}

 

a:hover,a:active{color:red;}

 

input:focus{background-color:yellow;}

 

(4).高级选择器

 

高级选择器,目前支持还不太完善,所以,对于站点功能很重要的任何元素上,应该避 免使用这些高级选择器.

 

10、子选择器和相邻同胞选择器

 

子选择器

#nav > li {
 
background:url(bg.gif) no-repeat left top;
 
}
 
<ul id="nav">   
 
  <li>Home</li>   
 
  <li>
 
    <ul>       
 
      <li>Development</li>       
 
      <li>Consultancy</li>     
 
    </ul>   
 
  </li>
 
  <li>Contact Us</li>
 
</ul>

 

相邻同胞选择器:

h1+p{font-weight:bold;}
 
<h1>Main Heading</h1>
 
<p>First Paragraph</p>
 
<p>Second Paragraph</p>

 

11、属性选择器

<strong title=”Cascading Style Sheets”>CSS</strong>
 
strong[title] {border-bottom: 1px dotted #999;}
 
strong[title]:hover {cursor:help;background:#ccc}
 
12、针对列表项特别好用的两个伪类选择器:
 
ol li:first-child{
 
  /*选中ol下面的第一个li*/
 
}
 
ol li:last-child{
 
  /*选中ol下面的一最后一个li*/
 
}
 
CSS3选择器新特性
 
a[href$=&#39;.jsp&#39;]{
 
  /*所有a标签中href属性为.jsp结尾的被选中*/
 
}
 
a[href^=&#39;asd]{
 
  /*所有a标签中href属性为asd开头的被选中*/
 
}
 
a[href*=&#39;asd]{
 
  /*所有a标签中href属性中包含asd的被选中*/
 
}

选择表中的行:

tr:nth-of-type(even){
 
  background-color:red;
 
  /*选中偶数行*/
 
}
 
tr:nth-of-type(odd){
 
  background-color:red;
 
  /*选中奇数行*/
 
}
 
tr:nth-of-child(n){
 
  background-color:red;
 
  /*选中所有行*/
 
}


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn