Jquery'Highlight'元素具有相同的类

时间:2011-01-20 20:09:20

标签: jquery image hover

我试图实现这个目标:

我有类似的东西:

<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上时,匹配类的图像会出现红色边框。我怎么能这样做?

非常感谢大家,我希望你能帮助我解决这个问题。

1 个答案:

答案 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','');
});