精品国产一区二区三区在线_国模极品一区二区三区_成人区精品一区二区不卡亚洲_久久久久国产一区二区

聯系方式Contact
地址:江蘇昆山市象嶼兩岸7號樓 15層
郵編:215300
資訊熱線:13405132033
郵箱:wj@kunxintong.com
文章搜索Search

CSS3選擇器:nth-child和:nth-of-type之間的差異

2016年09月23月 |發布者:管理員  點擊:

一、深呼吸,直接內容

:nth-child和:nth-of-type都是CSS3中的偽類選擇器,其作用近似卻又不完全一樣,對于不熟悉的人對其可能不是很區分,本文就將介紹兩者的不同,以便于大家正確靈活使用這兩類選擇器。

先看一個簡單的實例,首先是HTML部分:

<section>
    <p>我是第1個p標簽</p>
    <p>我是第2個p標簽</p>  <!-- 希望這個變紅 -->
</section>

然后兩個選擇器相對應的CSS代碼如下:

p:nth-child(2) { color: red; }
p:nth-of-type(2) { color: red; }

上面這個例子中,這兩個選擇器所實現的效果是一致的,第二個p標簽的文字變成了紅色,如下截圖(截自IE9):
CSS3 :nth-child和:nth-of-type選擇器差異第一個實例截圖

盡管上面兩個demo的最后效果一致,但是兩個選擇器之間存在差異是必然的。

對于:nth-child選擇器,在簡單白話文中,意味著選擇一個元素如果:

  1. 這是個段落元素
  2. 這是父標簽的第二個孩子元素

對于:nth-of-type選擇器,意味著選擇一個元素如果:

  1. 選擇父標簽的第二個段落子元素

:nth-of-type選擇器,恩……怎么講呢?限制條件少點~~

我們把上面的實例稍作修改,就可以看到這兩個選擇器之間的差異表現了,如下HTML代碼:

<section>
    <div>我是一個普通的div標簽</div>
    <p>我是第1個p標簽</p>
    <p>我是第2個p標簽</p>  <!-- 希望這個變紅 -->
</section>

還是與上面例子一致的CSS測試代碼:

p:nth-child(2) { color: red; }
p:nth-of-type(2) { color: red; }

這時候兩個選擇器所渲染的結果就不一樣了。

p:nth-child(2)悲劇了,其渲染的結果不是第二個p標簽文字變紅,而是第一個p標簽,也就是父標簽的第二個子元素。如下效果截圖:
CSS3 :nth-child和:nth-of-type選擇器差異實例頁面截圖

您可以狠狠地點擊這里::nth-child測試demo2

p:nth-of-type(2)的表現顯得很堅挺,其把希望渲染的第二個p標簽染紅了,如下截圖:
CSS3 :nth-child和:nth-of-type選擇器差異實例頁面截圖 張鑫旭-鑫空間-鑫生活

您可以狠狠地點擊這里::nth-of-type測試demo2

對照上面兩個選擇器的語義,此處的效果表現差異不難理解。

對于p:nth-child(2)表示這個元素要是p標簽,且是第二個子元素,是兩個必須滿足的條件。于是,就是第一個p標簽顏色為紅色(正好符合:p標簽,第二個子元素)。如果在div標簽后面再插入個span標簽,如下:

<section>
    <div>我是一個普通的div標簽</div>
    <span>我是一個普通的span標簽</span>
    <p>我是第1個p標簽</p>
    <p>我是第2個p標簽</p>  <!-- 希望這個變紅 -->
</section>

那么p:nth-child(2)將不會選擇任何元素。

p:nth-of-type(2)表示父標簽下的第二個p元素,顯然,無論在div標簽后面再插入個span標簽,還是h1標簽,都是第二個p標簽中的文字變紅。

這兩者的差異用一個跟切合實際的情況比喻就是計劃生育查人口:前者是如果是第二胎,且是女孩,罰款!后者是管他第幾胎,第二個出身的女孩,罰款!

二、二次深呼吸,個人體會

老實講,對于:nth-child和:nth-of-type這兩個屬性自己用的并不多,對這兩個屬性的認識就像是一團漿糊。印象在使用:last-child這個類似選擇器的時候,出現了沒有效果的情況,現在想想,就是因為對選擇器的理解不夠透徹,所以使用的時候出問題的。

今天對這兩個選擇器好好地過了遍之后,個人覺得:nth-of-type更彪悍些,不容易出問題,盡管:nth-child貌似更常見些。所以以后要選擇某某元素下的第幾個什么標簽,建議使用:nth-of-type,因為頁面元素插入其他標簽啊什么的是比較常見的,如果使用:nth-child,選擇器可能就是嗝屁。

不過嘛,世事無絕對,最靠譜的就是對這兩個選擇器徹徹底底地了解,具體情況具體使用。

另外一個小小的建議,為了避免出現“尼瑪我的:nth-child變成打醬油的不頂鳥用啦!”這樣的疑問,最好使用父標簽層級限制,而不是當前標簽類型限制。如下示例:

dl :nth-child(2) {  } /* 恩,這個要靠譜些 */
dd:nth-child(2) {  } /* 這個還需要多多斟酌 */

當然,還是那句話,要看實際情況如何,沒有一勞永逸,一方通行的代碼。

目前各個瀏覽器對這兩個選擇器的支持還是挺讓人欣慰的,Firefox 3.5+, Opera 9.5+, Chrome 2+, Safari 3.1+, IE 9+都是pass的。外帶一提的是jQuery支持基本上大多的選擇器,但是,其中并不包括這里的:nth-of-type,好像是因為這個選擇器用的比較少。如果你想讓jQuery也支持該選擇器,可以使用jQuery選擇器擴展插件,完美支持各個CSS3選擇器,要查看此插件請輕輕地點擊這里:jQuery CSS3選擇器擴展插件

對了,同等類型的CSS3偽類選擇器并不止這兩個, :first-of-type, :last-of-type, :nth-last-of-type 以及 :only-of-type等,以后有機會的話會簡單介紹這幾個選擇器的。

三、最后的深呼吸,吐氣,淡然的結語

我之前寫過一篇頗有爭議的文章:精簡高效的CSS命名準則/方法。根據里面的觀點,像:nth-child:nth-of-type這類選擇器應該少用為妙,一是性能,二是本身限制了內容的重用性。

但是,還是那句話,凡事無絕對。有時候因為設計的特殊性,我們可能需要有可以方便控制某些特殊元素的方法,例如浮動列表邊緣處的列表不能有 margin值以實現兩端對齊效果,等。此時CSS3選擇器是權衡下來的最優解決方案。因此,熟悉與理解CSS3中的各個選擇器還是有必要的。

隨著IE6~8瀏覽器緩慢地日落,CSS3的時代可能就會在不知不覺中到來,面對這必然的趨勢,我們是時候做好準備了。

感謝閱讀,歡迎糾錯。

 

原創文章,轉載請注明來自張鑫旭-鑫空間-鑫生活[http://www.zhangxinxu.com/wordpress/?p=1709]

QQ在線咨詢
客戶服務熱線:
13405132033
地址:
江蘇省昆山市創業路800號中創商業中心1號樓20層
精品国产一区二区三区在线_国模极品一区二区三区_成人区精品一区二区不卡亚洲_久久久久国产一区二区

        9000px;">

              久久久久久久久久成人| 欧美激情一区二区视频 | 麻豆一区在线观看| 久久99久久98精品免观看软件| 好吊色视频一区二区| 久久黄色免费网站| 日本一本在线观看| 伊人网伊人影院| 91福利视频免费观看| 国产 中文 字幕 日韩 在线| 精品99在线观看| 欧美一区二区三区影院| 黄色在线视频网| 欧美性猛交bbbbb精品| 午夜欧美福利视频| 亚洲一区二区三区蜜桃| 国产大学生av| 欧美成人精品一区二区综合免费| 神马久久精品综合| 91狠狠综合久久久久久| 国产综合精品视频| 色婷婷在线影院| 91亚洲精品国偷拍自产在线观看 | 久久久久久久久久99| 日韩欧美亚洲另类| 一二三四在线观看视频| 黑人精品一区二区三区| 日韩一区二区三区久久| 91看片在线播放| 久久久久99精品成人片毛片| 亚洲AV无码精品自拍| 超碰在线人人干| 欧美人妻一区二区| 亚洲图片视频小说| 久久精品亚洲无码| 中文字幕一区二区三区人妻| 国产人妖一区二区| 天天碰免费视频| 东京热av一区| 日韩久久中文字幕| 波多野结衣视频免费观看| 久久久久亚洲av片无码| 亚洲国产精品久久人人爱潘金莲| 国产三区在线播放| 在线免费看av网站| 精品国产99久久久久久宅男i| 香蕉成人在线视频| 国产一级淫片久久久片a级| 微拍福利一区二区| 好看的av在线| 亚洲熟妇无码久久精品| 欧美三级黄色大片 | 在线观看国产精品入口男同| 国产精品久久久久久久久夜色| 日韩丰满少妇无码内射| 波多野结衣亚洲色图| 手机看片一区二区三区| 国产一级精品毛片| 手机在线成人av| 国产三级精品三级在线观看| 亚洲最大成人av| 538精品视频| 日韩成人av免费| 国产精品久久久久久69| 亚洲av无码片一区二区三区| 精品人妻无码一区二区三区蜜桃一| 中文字幕视频一区二区| 日本视频www| 国内av免费观看| 99久久精品免费视频| 少妇久久久久久久久久| 国产一区二区三区影院| 2019男人天堂| 中文天堂资源在线| 日本不卡一区在线| 精品人妻少妇嫩草av无码| 999在线精品视频| 在线观看国产一级片| 欧美一级特黄aaaaaa大片在线观看| 丰满少妇被猛烈进入一区二区| 中文亚洲av片在线观看| 日韩在线观看视频一区| 久久出品必属精品| 国产福利拍拍拍| 亚洲综合欧美综合| 中文字幕一区二区三区手机版 | 在线观看一二三区| 日韩电影在线观看一区二区| 久久av无码精品人妻系列试探| 不卡中文字幕在线观看| 亚洲国产欧美日韩在线| 午夜激情在线观看视频| 日日碰狠狠添天天爽| 人妻少妇偷人精品久久久任期 | 国产精品51麻豆cm传媒| 亚洲一区二区三区综合| 最近中文字幕免费| 亚洲不卡免费视频| 午夜免费福利影院| 日韩精品人妻中文字幕有码| 欧美成人三级在线播放| 久久久久中文字幕亚洲精品| 国产在线视频卡一卡二| 国产又大又粗又爽| 国产一区二区精彩视频| 国产日韩欧美视频在线观看| 国产高清中文字幕| 国产麻豆剧传媒精品国产| 国产黄色片在线| 国产精品伦子伦| 国产精选久久久| 精品国产xxx| 久久久久亚洲av无码专区桃色| 精品少妇人妻av一区二区三区| 国产又大又长又粗| 国产又粗又长视频| 久久6免费视频| 免费一级片在线观看| 青青草国产在线观看| 日韩在线观看视频一区二区三区| 日韩中文字幕在线观看视频| 无码人妻精品一区二区50| 性猛交xxxx| 欧美亚洲精品天堂| 色呦呦免费观看| 中文字幕69页| www男人天堂| 国产日韩一级片| 麻豆一区二区三区视频| 日本 欧美 国产| 亚洲成av人片在线观看无| 亚洲色图欧美视频| 成人亚洲免费视频| 久久久久久久极品内射| 秋霞网一区二区三区| 性感美女一级片| av天堂一区二区| 国产一区二区三区影院| 免费一级特黄特色大片| 五月天婷婷在线播放| 一本一道久久a久久综合蜜桃| 丰满熟妇乱又伦| 蜜桃精品成人影片| 亚欧美在线观看| 成人免费毛片东京热| 久久久精品人妻无码专区| 日日噜噜夜夜狠狠| 91视频免费观看网站| 黑人精品一区二区三区| 日韩在线视频免费播放| 亚洲欧美激情另类| 国产亚洲精品熟女国产成人| 日韩精品在线免费看| 亚洲欧美综合视频| 精品黑人一区二区三区国语馆 | 欧美综合视频在线| 中文字幕免费高清| 国产九九在线观看| 日韩a一级欧美一级| 91国产丝袜播放在线| 久久久久久国产精品视频| 性色国产成人久久久精品| 非洲一级黄色片| 日韩欧美不卡视频| a毛片在线免费观看| 男人天堂av电影| 一级黄色性视频| 免费中文字幕在线观看| 亚洲图片欧美在线| 久久人人爽av| 一道本视频在线观看| 欧美日韩一区二区区| 91久久精品无码一区二区| 久久久久亚洲av成人无码电影| 综合 欧美 亚洲日本| 精品人妻少妇AV无码专区 | 伊人网伊人影院| 久久免费在线观看视频| 日韩特黄一级片| 天堂av在线网站| 丰满人妻一区二区三区无码av| 精品人妻一区二区三区免费| 中国1级黄色片| 久久久.www| 99热这里只有精| 三级全黄做爰视频| 国产精品视频一区二区三| 一区二区三区免费在线视频| 精品人妻一区二区三区视频| 91pony九色| 网站一区二区三区| 久久黄色一级视频| 91tv国产成人福利| 少妇人妻丰满做爰xxx| 国内偷拍精品视频| 亚洲欧美日韩三级| 天天躁夜夜躁狠狠是什么心态| 国内精品久久99人妻无码| 1024在线看片| 午夜免费福利影院|