CSS'de (veya başka herhangi bir sözde seçicide) :after
ile :hover
öğelerini birleştirmek istiyorum. Temelde bir listem var ve selected
sınıfına sahip öğe :after
kullanılarak uygulanan bir ok şekline sahip. Aynı şeyin üzerine gelinen nesneler için de geçerli olmasını istiyorum ama bunu tam olarak başaramıyorum. İşte kod
#alertlist
{
list-style:none;
width: 250px;
}
#alertlist li
{
padding: 5px 10px;
border-bottom: 1px solid #e9e9e9;
position:relative;
}
#alertlist li.selected, #alertlist li:hover
{
color: #f0f0f0;
background-color: #303030;
}
#alertlist li.selected:after
{
position:absolute;
top: 0;
right:-10px;
bottom:0;
border-top: 10px solid transparent;
border-bottom: 10px solid transparent;
border-left: 10px solid #303030;
content: "";
}
<ul id="alertlist">
<li>Alert 123</li>
<li class="selected">Alert 123</li>
<li>Alert 123</li>
</ul>
Sadece #alertlist li:hover
seçicinize #alertlist li.selected
seçicinizde yaptığınız gibi :after
ekleyin:
#alertlist li.selected:after, #alertlist li:hover:after
{
position:absolute;
top: 0;
right:-10px;
bottom:0;
border-top: 10px solid transparent;
border-bottom: 10px solid transparent;
border-left: 10px solid #303030;
content: "";
}
#alertlist li:hover:after,#alertlist li.selected:after
{
position:absolute;
top: 0;
right:-10px;
bottom:0;
border-top: 10px solid transparent;
border-bottom: 10px solid transparent;
border-left: 10px solid #303030;
content: "";
}
[jsFiddle Link][1]