5.31 css選擇器-三大特性

CSS選擇器

標(biāo)簽選擇器

  • 什么是標(biāo)簽選擇器?

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

  • 格式:

標(biāo)簽名稱{
  屬性:值;
}
  • 注意點(diǎn):
  • 標(biāo)簽選擇器選中的是當(dāng)前界面中所有的標(biāo)簽, 而不能單獨(dú)選中某一個(gè)標(biāo)簽
  • 標(biāo)簽選擇器無論標(biāo)簽藏得多深都能選中

id選擇器

  • 什么是id選擇器?

  • 作用: 根據(jù)指定的id名稱找到對(duì)應(yīng)的標(biāo)簽, 然后設(shè)置屬性

  • 格式

#id名稱{
  屬性:值;
}
  • 注意點(diǎn)
  • 個(gè)HTML標(biāo)簽都有一個(gè)屬性叫做id, 也就是說每個(gè)標(biāo)簽都可以設(shè)置id
  • 在同一個(gè)界面中id的名稱是不可以重復(fù)的
  • 在編寫id選擇器時(shí)一定要在id名稱前面加上#
  • id的名稱是有一定的規(guī)范的
  • id的名稱只能由字母/數(shù)字/下劃線(a-z 0-9 _)
  • id名稱不能以數(shù)字開頭
  • id名稱不能是HTML標(biāo)簽的名稱()不能是a h1 img input ...)
  • 在企業(yè)開發(fā)中一般情況下如果僅僅是為了設(shè)置樣式, 我們不會(huì)使用id ,因?yàn)樵谇岸碎_
    發(fā)中id一般留給js使用的

類選擇器

  • 什么是類選擇器?

  • 作用: 根據(jù)指定的類名稱找到對(duì)應(yīng)的標(biāo)簽, 然后設(shè)置屬性

  • 格式

.類名{
  屬性:值;
}
  • 注意點(diǎn):
  • 每個(gè)HTML標(biāo)簽都有一個(gè)屬性叫做class, 也就是說每個(gè)標(biāo)簽都可以設(shè)置類名
  • 在同一個(gè)界面中class的名稱是可以重復(fù)的
  • 在編寫class選擇器時(shí)一定要在class名稱前面加上點(diǎn)
  • 類名的命名規(guī)范和id名稱的命名規(guī)范一樣
  • 類名就是專門用來給CSS設(shè)置樣式的
  • 在HTML中每個(gè)標(biāo)簽可以同時(shí)綁定多個(gè)類名
格式:
<標(biāo)簽名稱 class="類名1 類名2 ...">
錯(cuò)誤的寫法:
<p class="para1" class="para2">

id選擇器和類選擇器

  • id和class的區(qū)別?

  • 1.1

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

    • 一個(gè)HTML標(biāo)簽只能綁定一個(gè)id名稱
    • 一個(gè)HTML標(biāo)簽可以綁定多個(gè)class名稱
  • d選擇器和class選擇器區(qū)別?

  • id選擇器是以#開頭

  • class選擇器是以.開頭

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

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

  • 在企業(yè)開發(fā)中一個(gè)開發(fā)人員對(duì)類的使用可以看出這個(gè)開發(fā)人員的技術(shù)水平

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

后代選擇器

  • 什么是后代選擇器?

  • 作用: 找到指定標(biāo)簽的所有特定的后代標(biāo)簽, 設(shè)置屬性

  • 格式:

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

  • 注意點(diǎn):

  • 后代選擇器必須用空格隔開

  • 后代不僅僅是兒子, 也包括孫子/重孫子, 只要最終是放到指定標(biāo)簽中的都是后代

  • 后代選擇器不僅僅可以使用標(biāo)簽名稱, 還可以使用其它選擇器

  • 后代選擇器可以通過空格一直延續(xù)下去

子元素選擇器

  • 什么是子元素選擇器?

  • 作用: 找到指定標(biāo)簽中所有特定的直接子元素, 然后設(shè)置屬性

  • 格式:

標(biāo)簽名稱1>標(biāo)簽名稱2{
  屬性:值;
}
  • 先找到所有名稱叫做"標(biāo)簽名稱1"的標(biāo)簽, 然后在這個(gè)標(biāo)簽中查找所有直接子元素名稱叫做"標(biāo)簽名稱2"的元素

  • 注意點(diǎn):

  • 子元素選擇器只會(huì)查找兒子, 不會(huì)查找其他被嵌套的標(biāo)簽

  • 子元素選擇器之間需要用>符號(hào)連接, 并且不能有空格

  • 子元素選擇器不僅僅可以使用標(biāo)簽名稱, 還可以使用其它選擇器

  • 子元素選擇器可以通過>符號(hào)一直延續(xù)下去

后代選擇器和子元素選擇器

  • 后代選擇器和子元素選擇器之間的區(qū)別?

  • 1.1

    • 后代選擇器使用空格作為連接符號(hào)
    • 子元素選擇器使用>作為連接符號(hào)
  • 1.2

    • 后代選擇器會(huì)選中指定標(biāo)簽中, 所有的特定后代標(biāo)簽, 也就是會(huì)選中兒子/孫子..., 只要是被放到指定標(biāo)簽中的特定標(biāo)簽都會(huì)被選中
    • 子元素選擇器只會(huì)選中指定標(biāo)簽中, 所有的特定的直接標(biāo)簽, 也就是只會(huì)選中特定的兒子標(biāo)簽
  • 后代選擇器和子元素選擇器之間的共同點(diǎn)

  • 2.1

    • 后代選擇器和子元素選擇器都可以使用標(biāo)簽名稱/id名稱/class名稱來作為選擇器
  • 2.2

    • 后代選擇器和子元素選擇器都可以通過各自的連接符號(hào)一直延續(xù)下去
      選擇器1>選擇器2>選擇器3>選擇器4{}
  • 在企業(yè)開發(fā)中如何選擇

  • 如果想選中指定標(biāo)簽中的所有特定的標(biāo)簽, 那么就使用后代選擇器

  • 如果只想選中指定標(biāo)簽中的所有特定兒子標(biāo)簽, 那么就使用子元素選擇器

交集選擇器

  • 什么是交集選擇器?

  • 作用: 給所有選擇器選中的標(biāo)簽中, 相交的那部分標(biāo)簽設(shè)置屬性

  • 格式:

選擇器1選擇器2{
  屬性: 值;
}
  • 注意點(diǎn):

  • 選擇器和選擇器之間沒有任何的連接符號(hào)

  • 選擇器可以使用標(biāo)簽名稱/id名稱/class名稱

  • 交集選擇器僅僅作為了解, 企業(yè)開發(fā)中用的并不多

交集一定要范圍大的在前邊

并集選擇器

  • 什么是并集選擇器?

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

  • 格式:

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

兄弟選擇器

  • 相鄰兄弟選擇器
  • 什么是相鄰兄弟選擇器 CSS2

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

  • 格式:

選擇器1+選擇器2{
  屬性:值;
}
  • 注意點(diǎn):
  • 相鄰兄弟選擇器必須通過+連接
  • 相鄰兄弟選擇器只能選中緊跟其后的那個(gè)標(biāo)簽, 不能選中被隔開的標(biāo)簽
  • 通用兄弟選擇器
  • 什么是通用兄弟選擇器 CSS3

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

  • 格式:

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

序選擇器

  • 序選擇器是CSS3中新增的選擇器最具代表性的就是序選擇器

  • 什么是序選擇器?

  • 作用: 選中指定的任意標(biāo)簽然后設(shè)置屬性

  • 格式:

  • 1.同級(jí)別的第幾個(gè)

    • :first-child 選中同級(jí)別中的第一個(gè)標(biāo)簽
    • :last-child 選中同級(jí)別中的最后一個(gè)標(biāo)簽
  • :nth-child(n) 選中同級(jí)別中的第n個(gè)標(biāo)簽

  • :nth-last-child(n) 選中同級(jí)別中的倒數(shù)第n個(gè)標(biāo)簽

  • :only-child 選中父元素中唯一的標(biāo)簽

  • 注意點(diǎn): 不區(qū)分類型

  • 2.同級(jí)同類型的第幾個(gè)

  • :first-of-type 選中同級(jí)別中同類型的第一個(gè)標(biāo)簽

  • :last-of-type 選中同級(jí)別中同類型的最后一個(gè)標(biāo)簽

  • :nth-of-type(n) 選中同級(jí)別中同類型的第n個(gè)標(biāo)簽

  • :nth-last-of-type(n) 選中同級(jí)別中同類型的倒數(shù)第n個(gè)標(biāo)簽

  • :only-of-type 選中父元素中唯一類型的某個(gè)標(biāo)簽

  • 3.其它用法

  • :nth-child(odd) 選中同級(jí)別中的所有奇數(shù)

  • :nth-child(even) 選中同級(jí)別中的所有偶數(shù)

  • :nth-child(xn+y)

  • x和y是用戶自定義的, 而n是一個(gè)計(jì)數(shù)器, 從0開始遞增

  • :nth-of-type(odd) 選中同級(jí)別中同類型的所有奇數(shù)

  • :nth-of-type(even) 選中同級(jí)別中同類型的所有偶數(shù)

  • :nth-of-type(xn+y)

  • x和y是用戶自定義的, 而n是一個(gè)計(jì)數(shù)器, 從0開始遞增

屬性選擇器

  • 什么是屬性選擇器?

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

  • 格式:

[attribute]
  • 作用:根據(jù)指定的屬性名稱找到對(duì)應(yīng)的標(biāo)簽, 然后設(shè)置屬性
[attribute=value]
  • 作用: 找到有指定屬性, 并且屬性的取值等于value的標(biāo)簽, 然后設(shè)置屬性
  • 最常見的應(yīng)用場(chǎng)景, 就是用于區(qū)分input屬性
input[type=password]{}
<input type="text" name="" id="">
<input type="password" name="" id="">
  • 屬性的取值是以什么開頭的

  • [attribute|=value] CSS2

  • [attribute^=value] CSS3

  • 兩者之間的區(qū)別:

  • CSS2中的只能找到value開頭,并且value是被-和其它內(nèi)容隔開的

  • CSS3中的只要是以value開頭的都可以找到, 無論有沒有被-隔開

  • 屬性的取值是以什么結(jié)尾的

  • [attribute$=value] CSS3

  • 屬性的取值是否包含某個(gè)特定的值得

  • [attribute~=value] CSS2

  • [attribute*=value] CSS3

  • 兩者之間的區(qū)別:

  • CSS2中的只能找到獨(dú)立的單詞, 也就是包含value,并且value是被空格隔開的

  • CSS3中的只要包含value就可以找到, 無論有沒有被隔開

通配符選擇器

  • 什么是通配符選擇器?

  • 作用: 給當(dāng)前界面上所有的標(biāo)簽設(shè)置屬性

  • 格式:

*{
  屬性:值;
}
  • 注意點(diǎn):

  • 由于通配符選擇器是設(shè)置界面上所有的標(biāo)簽的屬性, 所以在設(shè)置之前會(huì)遍歷所有的標(biāo)簽, 如果當(dāng)前界面上的標(biāo)簽比較多, 那么性能就會(huì)比較差, 所以在企業(yè)開發(fā)中一般不會(huì)使用通配符選擇器

CSS三大特性

繼承性

  • 什么是繼承性?

  • 作用: 給父元素設(shè)置一些屬性, 子元素也可以使用, 這個(gè)我們就稱之為繼承性

  • 示例代碼:

css三大特性之繼承性.png
繼承性注意點(diǎn).png
  • 注意點(diǎn):
    • 并不是所有的屬性都可以繼承, 只有以color/font-/text-/line-開頭的屬性才可以繼承
    • 在CSS的繼承中不僅僅是兒子可以繼承, 只要是后代都可以繼承
    • 繼承性中的特殊性
    • a標(biāo)簽的文字顏色和下劃線是不能繼承的
    • h標(biāo)簽的文字大小是不能繼承的
  • 應(yīng)用場(chǎng)景:
  • 一般用于設(shè)置網(wǎng)頁上的一些共性信息, 例如網(wǎng)頁的文字顏色, 字體,文字大小等內(nèi)容

層疊性

CSS全稱 Cascading StyleSheet (層疊式樣式表), 其中的層疊就是指層疊性

  • 什么是層疊性?

  • 作用: 層疊性就是CSS處理沖突的一種能力

  • 示例代碼

層疊性
  • 最終顯示藍(lán)色, 因?yàn)榧t色被覆蓋掉了

優(yōu)先級(jí)

  • 1 什么是優(yōu)先級(jí)?

  • 作用:當(dāng)多個(gè)選擇器選中同一個(gè)標(biāo)簽, 并且給同一個(gè)標(biāo)簽設(shè)置相同的屬性時(shí), 如何層疊就由優(yōu)先級(jí)來確定

  • 2.優(yōu)先級(jí)判斷的三種方式

  • 2.1間接選中就是指繼承

    • 如果是間接選中, 那么就是誰離目標(biāo)標(biāo)簽比較近就聽誰的
  • 2.2相同選擇器(直接選中)

    • 如果都是直接選中, 并且都是同類型的選擇器, 那么就是誰寫在后面就聽誰的
  • 2.3不同選擇器(直接選中)

    • 如果都是直接選中, 并且不是相同類型的選擇器, 那么就會(huì)按照選擇器的優(yōu)先級(jí)來層疊
優(yōu)先級(jí):

   id>類>標(biāo)簽>通配符>繼承>瀏覽器默認(rèn)
  • 注意點(diǎn):
  • 通配符選擇器也是直接選中

優(yōu)先級(jí)權(quán)重

  • 什么是優(yōu)先級(jí)的權(quán)重?

  • 作用: 當(dāng)多個(gè)選擇器混合在一起使用時(shí), 我們可以通過計(jì)算權(quán)重來判斷誰的優(yōu)先級(jí)最高

  • 權(quán)重的計(jì)算規(guī)則

  • 首先先計(jì)算選擇器中有多少個(gè)id, id多的選擇器優(yōu)先級(jí)最高

  • 如果id的個(gè)數(shù)一樣, 那么再看類名的個(gè)數(shù), 類名個(gè)數(shù)多的優(yōu)先級(jí)最高

  • 如果類名的個(gè)數(shù)一樣, 那么再看標(biāo)簽名稱的個(gè)數(shù), 標(biāo)簽名稱個(gè)數(shù)多的優(yōu)先級(jí)最高

  • 如果id個(gè)數(shù)一樣, 類名個(gè)數(shù)也一樣, 標(biāo)簽名稱個(gè)數(shù)也一樣, 那么就不會(huì)繼續(xù)往下計(jì)算了, 那么此時(shí)誰寫在后面聽誰的

  • 示例代碼

image.png
image.png
image.png
image.png
  • 注意點(diǎn):
  • 只有選擇器是直接選中標(biāo)簽的才需要計(jì)算權(quán)重, 否則一定會(huì)聽直接選中的選擇器的

!important

  • 什么是!important

  • 作用: 用于提升某個(gè)直接選中標(biāo)簽的選擇器中的某個(gè)屬性的優(yōu)先級(jí)的, 可以將被指定的屬性的優(yōu)先級(jí)提升為最高
    -示例代碼

image.png
  • 注意點(diǎn):

  • !important只能用于直接選中, 不能用于間接選中

  • 通配符選擇器選中的標(biāo)簽也是直接選中的

  • !important只能提升被指定的屬性的優(yōu)先級(jí), 其它的屬性的優(yōu)先級(jí)不會(huì)被提升

  • !important必須寫在屬性值得分號(hào)前面

  • !important前面的感嘆號(hào)不能省略

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末寻咒,一起剝皮案震驚了整個(gè)濱河市吐葱,隨后出現(xiàn)的幾起案子定鸟,更是在濱河造成了極大的恐慌霞溪,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)幌缝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诫欠,“玉大人狮腿,你說我怎么就攤上這事∨凰撸” “怎么了缘厢?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)甩挫。 經(jīng)常有香客問我贴硫,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任英遭,我火速辦了婚禮间护,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘挖诸。我一直安慰自己汁尺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布多律。 她就那樣靜靜地躺著痴突,像睡著了一般。 火紅的嫁衣襯著肌膚如雪狼荞。 梳的紋絲不亂的頭發(fā)上辽装,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音相味,去河邊找鬼拾积。 笑死,一個(gè)胖子當(dāng)著我的面吹牛丰涉,可吹牛的內(nèi)容都是我干的拓巧。 我是一名探鬼主播,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼一死,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼肛度!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起摘符,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤贤斜,失蹤者是張志新(化名)和其女友劉穎策吠,沒想到半個(gè)月后逛裤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡猴抹,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年带族,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蟀给。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蝙砌,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出跋理,到底是詐尸還是另有隱情择克,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布前普,位于F島的核電站肚邢,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜骡湖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一贱纠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧响蕴,春花似錦谆焊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至军拟,卻和暖如春剃执,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背懈息。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工肾档, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人辫继。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓怒见,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親姑宽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遣耍,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)炮车,斷路器舵变,智...
    卡卡羅2017閱讀 134,693評(píng)論 18 139
  • CSS選擇器 標(biāo)簽選擇器 什么是標(biāo)簽選擇器? 作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然...
    極客江南閱讀 11,779評(píng)論 10 109
  • 標(biāo)簽選擇器 什么是標(biāo)簽選擇器? 作用: 根據(jù)指定的標(biāo)簽名稱, 在當(dāng)前界面中找到所有該名稱的標(biāo)簽, 然后設(shè)置屬性格式...
    e919b03f06c2閱讀 292評(píng)論 0 0
  • 因你眉眼如畫 怎怪我心猿意馬
    硬撐qaq閱讀 105評(píng)論 0 0
  • 人情做透之短信+小禮物—搞定院長(zhǎng)扛或、科長(zhǎng) 案例一 這家客戶在已經(jīng)三年沒做進(jìn)去設(shè)備了绵咱,但是這個(gè)客戶最近確實(shí)有一筆錢要采...
    陳強(qiáng)紅閱讀 281評(píng)論 0 1