css3 - css中如何讓第一個和最后一個不被選中?
問題描述
tr:not(:first-child):hover {background: #ffffdd; }
這樣只能匹配讓第一行鼠標移動到上面時背景不變黃
tr:not(:last-child):hover {background: #ffffdd; }
這樣只能匹配讓最后一行鼠標移動到上面時背景不變黃
那么,問題來了.請問如何讓第一行和最后一行鼠標移動到上面時背景都不變黃呢?
問題解答
回答1:兩個 :not寫在一起就好了呀
.a { width: 80px; height:60px; background:#333; border: #eee solid 1px;}.a:not(:first-of-type):not(:last-of-type):hover { /* First-Of-Type 似乎更穩定 */ background: #ffffdd;}
<p class='a'></p><p class='a'></p><p class='a'></p><p class='a'></p><p class='a'></p>2016.9.24 更正
預覽好了。 底部
或者 :not(class)如果上面的代碼出現問題,使用下面的會更安全
.b { width: 80px; height:60px; background:#333; border: #eee solid 1px;}.b:not(.b-n):hover { background: #ffffdd;}
<p class='b b-n'></p><p class='b'></p><p class='b'></p><p class='b'></p><p class='b b-n'></p>預覽
http://codepen.io/KZ-DSF/pen/...
回答2:以ul為例
li:not(:first-child):hover{ background: #ff0000; } li:not(:last-child):hover{ background: #ff0000; } li:first-child:hover{ background: inherit; } li:last-child:hover{ background: inherit; }
其實只要將第一個和最后一個恢復原樣覆蓋就行了,那么下面也是可以的
li:hover{ background: #ff0000; } li:first-child:hover{ background: inherit; } li:last-child:hover{ background: inherit; }
相關文章:
1. java - 三位二進制表示8進制,四位二進制表示16進制,那么多少二進制表示10進制呢?2. docker 下面創建的IMAGE 他們的 ID 一樣?這個是怎么回事????3. 如何用筆記本上的apache做微信開發的服務器4. angular.js - ionic2 瀏覽器跨域問題5. 【python|scapy】sprintf輸出時raw_string轉string6. python - Scrapy存在內存泄漏的問題。7. docker-compose中volumes的問題8. android - rxjava merge 返回Object對象數據如何緩存9. mysql - 記得以前在哪里看過一個估算時間的網站10. java如何生成token?
