CSS選擇器

  • 標(biāo)簽選擇器(html中的標(biāo)簽名稱)
  • id選擇器(html標(biāo)簽中綁定的id名)
  • 類選擇器(html標(biāo)簽中綁定的class名)
  • 后代選擇器(某一個標(biāo)簽的后代--兒子,孫子。。。)
  • 子元素選擇器(某一個標(biāo)簽的兒子)
  • 交集選擇器
  • 并集選擇器
  • 兄弟選擇器
  • 偽類選擇器(序選擇器)
  • 屬性選擇器
  • 通配符選擇器

最常用的幾個:
標(biāo)簽,id,后代,并集,偽類

一般來說,最外層的使用id選擇器唯一確定,里面的使用class,標(biāo)簽就可以了

標(biāo)簽選擇器

1.什么是標(biāo)簽選擇器?
作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然后設(shè)置屬性

格式:

標(biāo)簽名稱{
    屬性:值;
}

注意點(diǎn):
1.標(biāo)簽選擇器選中的是當(dāng)前界面中所有的標(biāo)簽, 而不能單獨(dú)選中某一個標(biāo)簽
2.標(biāo)簽選擇器無論標(biāo)簽藏得多深都能選中
3.只要是HTML中的標(biāo)簽就可以作為標(biāo)簽選擇器(h/a/img/ul/ol/dl/input....)

id選擇器

1.什么是id選擇器?
作用: 根據(jù)指定的id名稱找到對應(yīng)的標(biāo)簽, 然后設(shè)置屬性

格式:

#id名稱{
    屬性:值;
}

注意點(diǎn):
1.每個HTML標(biāo)簽都有一個屬性叫做id, 也就是說每個標(biāo)簽都可以設(shè)置id
2.在同一個界面中id的名稱是不可以重復(fù)的
3.在編寫id選擇器時一定要在id名稱前面加上#
4.id的名稱是有一定的規(guī)范的

1. id的名稱只能由字母/數(shù)字/下劃線 a-z 0-9 _
2. id名稱不能以數(shù)字開頭
3. id名稱不能是HTML標(biāo)簽的名稱. 不能是a h1 img input ...

5.在企業(yè)開發(fā)中一般情況下如果僅僅是為了設(shè)置樣式, 我們不會使用id ,因為在前端開發(fā)中id是留給js使用的

類選擇器

1.什么是類選擇器?
作用: 根據(jù)指定的類名稱找到對應(yīng)的標(biāo)簽, 然后設(shè)置屬性

格式:

.類名{
    屬性:值;
}

注意點(diǎn):
1.每個HTML標(biāo)簽都有一個屬性叫做class, 也就是說每個標(biāo)簽都可以設(shè)置類名
2.在同一個界面中class的名稱是可以重復(fù)的
3.在編寫class選擇器時一定要在class名稱前面加上.
4.類名的命名規(guī)范和id名稱的命名規(guī)范一樣
5.類名就是專門用來給CSS設(shè)置樣式的
6.在HTML中每個標(biāo)簽可以同時綁定多個類名

格式:
<標(biāo)簽名稱 class="類名1 類名2 ...">
錯誤的寫法:
<p class="para1" class="para2">

id選擇器和類選擇器

1.id和class的區(qū)別?

1.
id相當(dāng)于人的身份證不可以重復(fù)
class相當(dāng)于人的名稱可以重復(fù)

2.
一個HTML標(biāo)簽只能綁定一個id名稱
一個HTML標(biāo)簽可以綁定多個class名稱

2.id選擇器和class選擇器區(qū)別?

* id選擇器是以#開頭
* class選擇器是以.開頭

3.在企業(yè)開發(fā)中到底用id選擇器還是用class選擇器?

id一般情況下是給js使用的, 所以除非特殊情況, 否則不要使用id去設(shè)置樣式

一般情況下在企業(yè)開發(fā)中要注重冗余代碼的抽取, 可以將一些公共的代碼抽取到一個類選擇器中, 然后讓標(biāo)簽和這個類選擇器綁定即可

后代選擇器

1.什么是后代選擇器?
作用: 找到指定標(biāo)簽的所有特定的后代標(biāo)簽, 設(shè)置屬性

格式:

標(biāo)簽名稱1 標(biāo)簽名稱2{
    屬性:值;
}

先找到所有名稱叫做"標(biāo)簽名稱1"的標(biāo)簽, 然后再在這個標(biāo)簽下面去查找所有名稱叫做"標(biāo)簽名稱2"的標(biāo)簽, 然后在設(shè)置屬性
div p{}

注意點(diǎn):
1.后代選擇器必須用空格隔開
2.后代不僅僅是兒子, 也包括孫子/重孫子, 只要最終是放到指定標(biāo)簽中的都是后代
3.后代選擇器不僅僅可以使用標(biāo)簽名稱, 還可以使用其它選擇器
4.后代選擇器可以通過空格一直延續(xù)下去

子元素選擇器

1.什么是子元素選擇器?
作用: 找到指定標(biāo)簽中所有特定的直接子元素, 然后設(shè)置屬性

格式:

標(biāo)簽名稱1>標(biāo)簽名稱2{
    屬性:值;
}

先找到所有名稱叫做"標(biāo)簽名稱1"的標(biāo)簽, 然后在這個標(biāo)簽中查找所有直接子元素名稱叫做"標(biāo)簽名稱2"的元素

注意點(diǎn):
1.子元素選擇器只會查找兒子, 不會查找其他被嵌套的標(biāo)簽
2.子元素選擇器之間需要用>符號連接, 并且不能有空格
3.子元素選擇器不僅僅可以使用標(biāo)簽名稱, 還可以使用其它選擇器
4.子元素選擇器可以通過>符號一直延續(xù)下去

交集選擇器

開發(fā)中基本不用

1.什么是交集選擇器?
作用: 給所有選擇器選中的標(biāo)簽中, 相交的那部分標(biāo)簽設(shè)置屬性

格式:

選擇器1選擇器2{
    屬性: 值;
}

注意點(diǎn):
1.選擇器和選擇器之間沒有任何的連接符號
2.選擇器可以使用標(biāo)簽名稱/id名稱/class名稱

并集選擇器

可以用來簡化代碼,非常常用

1.什么是并集選擇器?
作用: 給所有選擇器選中的標(biāo)簽設(shè)置屬性

格式:

選擇器1,選擇器2{
    屬性:值;
}

注意點(diǎn):
1.并集選擇器必須使用,來連接
2.選擇器可以使用標(biāo)簽名稱/id名稱/class名稱

兄弟選擇器

相鄰兄弟選擇器 CSS2

作用: 給指定選擇器后面緊跟的那個選擇器選中的標(biāo)簽設(shè)置屬性

格式:

選擇器1+選擇器2{
    屬性:值;
}

注意點(diǎn):
1.相鄰兄弟選擇器必須通過+連接
2.相鄰兄弟選擇器只能選中緊跟其后的那個標(biāo)簽, 不能選中被隔開的標(biāo)簽

通用兄弟選擇器 CSS3

作用: 給指定選擇器后面的所有選擇器選中的所有標(biāo)簽設(shè)置屬性

格式:

選擇器1~選擇器2{
    屬性:值;
}

注意點(diǎn):
1.通用兄弟選擇器必須用~連接
2.通用兄弟選擇器選中的是指定選擇器后面某個選擇器選中的所有標(biāo)簽, 無論有沒有被隔開都可以選中

偽類選擇器(序選擇器)

這幾個非常的常用,尤其是nth-of-type(n)
好處是,不需要取那么多的名字了(這是一個大問題),直接就可以拿到標(biāo)簽

CSS3中新增的選擇器最具代表性的就是序選擇器
1.同級別的第幾個
:first-child 選中同級別中的第一個標(biāo)簽
:last-child 選中同級別中的最后一個標(biāo)簽
:nth-child(n) 選中同級別中的第n個標(biāo)簽
:nth-last-child(n) 選中同級別中的倒數(shù)第n個標(biāo)簽
:only-child 選中父元素中唯一的標(biāo)簽
注意點(diǎn): 不區(qū)分類型

2.同類型的第幾個
:first-of-type 選中同級別中同類型的第一個標(biāo)簽
:last-of-type 選中同級別中同類型的最后一個標(biāo)簽
:nth-of-type(n) 選中同級別中同類型的第n個標(biāo)簽
:nth-last-of-type(n) 選中同級別中同類型的倒數(shù)第n個標(biāo)簽
:only-of-type 選中父元素中唯一類型的某個標(biāo)簽

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>19-序選擇器下</title>
    <style>
        p:nth-of-type(odd){
            color: red;
        }
        p:nth-of-type(even){
            color: blue;
        }
      
    </style>
</head>
<body>
<!--
:nth-child(odd) 選中同級別中的所有奇數(shù)
:nth-child(even) 選中同級別中的所有偶數(shù)

:nth-child(xn+y)
x和y是用戶自定義的, 而n是一個計數(shù)器, 從0開始遞增

-->
<p>我是項目</p>
<p>我是項目</p>
<p>我是項目</p>
<p>我是項目</p>
<p>我是項目</p>
<p>我是項目</p>
<p>我是項目</p>
</body>
</html>

屬性選擇器

去w3c看文檔吧

1.什么是屬性選擇器?
作用: 根據(jù)指定的屬性名稱找到對應(yīng)的標(biāo)簽, 然后設(shè)置屬性

格式:
[attribute]
作用:根據(jù)指定的屬性名稱找到對應(yīng)的標(biāo)簽, 然后設(shè)置屬性

[attribute=value]
作用: 找到有指定屬性, 并且屬性的取值等于value的標(biāo)簽, 然后設(shè)置屬性

最常見的應(yīng)用場景, 就是用于區(qū)分input屬性

input[type=password]{}
<input type="text" name="" id="">
<input type="password" name="" id="">

通配符選擇器

1.什么是通配符選擇器?
作用: 給當(dāng)前界面上所有的標(biāo)簽設(shè)置屬性

格式:

*{
    屬性:值;
}

注意點(diǎn):
由于通配符選擇器是設(shè)置界面上所有的標(biāo)簽的屬性, 所以在設(shè)置之前會遍歷所有的標(biāo)簽, 如果當(dāng)前界面上的標(biāo)簽比較多, 那么性能就會比較差, 所以在企業(yè)開發(fā)中一般不會使用通配符選擇器,有其他的方案來替代

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • CSS選擇器 標(biāo)簽選擇器 什么是標(biāo)簽選擇器? 作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然...
    Jackson_yee_閱讀 564評論 0 0
  • CSS選擇器 標(biāo)簽選擇器 什么是標(biāo)簽選擇器? 作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然...
    極客江南閱讀 11,923評論 10 109
  • 標(biāo)簽選擇器 什么是標(biāo)簽選擇器? 作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然后設(shè)置屬性格式...
    e919b03f06c2閱讀 324評論 0 0
  • 標(biāo)簽選擇器 什么是標(biāo)簽選擇器?作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然后設(shè)置屬性 格式...
    muyang_js的簡書閱讀 555評論 0 0
  • Pressing toward the Goal 12I don't mean to say that I hav...
    小綠植物閱讀 243評論 0 0

友情鏈接更多精彩內(nèi)容