我有这个JavaScript代码,当您将鼠标悬停在相关的锚标记上时会改变图像的不透明度。我想知道如何让它反向工作?将鼠标悬停在图像上时更改锚标记。
的JavaScript
$('.link a').hover(
function () {
$('img.'+$(this).attr('class')).addClass('hovered');
},
function () {
$('img.'+$(this).attr('class')).removeClass('hovered');
});
HTML
<ul>
<li><div class="link"><a href="#" class="link_a">Link A</a></div></li>
<li><div class="link"><a href="#" class="link_b">Link B</a></div></li>
<li><a href="#"><img class="link_a" src="http://somthing.jpg" /></a></li>
<li><a href="#"><img class="link_b" src="http://somthing.jpg" /></a></li>
</ul>
CSS
.hovered {opacity: 1.0;}
img {opacity: 0.5;}
img:hover {opacity: 1.0;}
谢谢。
答案 0 :(得分:1)
查看我的 example ,如果您有任何疑问,请与我们联系。
$('.link a').hover(
function () {
$('img.'+$(this).attr('class')).addClass('hovered');
},
function () {
$('img.'+$(this).attr('class')).removeClass('hovered');
});
$('img.link_a').hover(
function () {
$('a.link_a').addClass('hovered');
},
function () {
$('a.link_a').removeClass('hovered');
});
$('img.link_b').hover(
function () {
$('a.link_b').addClass('hovered');
},
function () {
$('a.link_b').removeClass('hovered');
});
答案 1 :(得分:1)
在这种情况下,你应该处理id而不是类,以便有一个通用的解决方案,看看here
HTML:
<ul>
<li><div class="link"><a href="#" id="link_a" class="hoverLink">Link A</a></div></li>
<li><div class="link"><a href="#" id="link_b" class="hoverLink">Link B</a></div></li>
<li><a href="#"><img id="link_a_img" class="hoverImg" src="http://images.apple.com/support/ipod/images/do_not_disconnect_icon.gif" /></a></li>
<li><a href="#"><img id="link_b_img" class="hoverImg" src="http://atlanta.braves.mlb.com/images/global/alert_icon.gif" /></a></li>
</ul>
JS:
$('.link a').hover(
function () {
$('#' + $(this).attr('id') + '_img').addClass('hovered');
},
function () {
$('#' + $(this).attr('id') + '_img').removeClass('hovered');
});
$('img.hoverImg').hover(
function () {
var idParts = $(this).attr('id').split('_');
var id = idParts[0] + "_" + idParts[1];
$('#' + id).addClass('hovered');
},
function () {
var idParts = $(this).attr('id').split('_');
var id = idParts[0] + "_" + idParts[1];
$('#' + id).removeClass('hovered');
});
CSS:
.hovered {opacity: 1.0; font-weight:bold;}
img {opacity: 0.5;}
img:hover {opacity: 1.0;}