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. javascript - node.js promise沒用2. golang - 用IDE看docker源碼時的小問題3. yii2中restful配置好后在nginx下報404錯誤4. 算法 - python 給定一個正整數a和一個包含任意個正整數的 列表 b,求所有<=a 的加法組合5. android 如何實現如圖中的鍵盤上的公式及edittext的內容展示呢6. java - 我在用Struts2上傳文件時,報以下錯誤怎么回事?7. c++ - 如何正確的使用QWebEngineView?8. PHP注冊功能9. mysql - 求SQL語句10. MySQL如何實現表中再嵌套一個表?
