我有类似的东西:
<ul>
<li><a href="#" class="class-1">Link 1</a></li>
<li><a href="#" class="class-2">Link 2</a></li>
<li><a href="#" class="class-3">Link 3</a></li>
</ul>
<img src="img-desc.jpg" class="class-1" />
<img src="img-desc-1.jpg" class="class-2" />
<img src="img-desc-2.jpg" class="class-3" />
我希望每次用户将鼠标悬停在其中一个ul&gt; li上时,匹配类的图像会出现红色边框。我怎么能这样做?
非常感谢大家,我希望你能帮助我解决这个问题。
答案 0 :(得分:5)
你可以这样做:
示例: http://jsfiddle.net/Q7knH/
$('ul > li').hover(function() {
$('img.' + $(this).children('a').attr('class') ).css('border','2px solid red');
},function() {
$('img.' + $(this).children('a').attr('class') ).css('border','');
});
或者如果您确定<li>
元素在<a>
周围没有任何空格,则可以缩短一点:
示例: http://jsfiddle.net/Q7knH/1/
$('ul > li').hover(function() {
$('img.' + this.firstChild.className ).css('border','2px solid red');
},function() {
$('img.' + this.firstChild.className ).css('border','');
});
或者如果您希望悬停发生在<a>
上,请执行以下操作:
示例: http://jsfiddle.net/Q7knH/3/
$('ul > li > a').hover(function() {
$('img.' + this.className ).css('border','2px solid red');
},function() {
$('img.' + this.className ).css('border','');
});