获取鼠标悬停的元素的属性

时间:2013-03-29 02:14:36

标签: jquery hover selection mouseover attr

我正在尝试为我的网站制作一个传奇系统..这是一项简单的任务...... 当鼠标悬停在元素上时,jquery获取value属性并将此值添加到下面的div ...

我不知道如何获取属性,因为选择返回3个元素... 这是代码..

$(function(){
$('#legends .item')
    .mouseover(function(){
            $('#legend-tags').html($('#tag-video').attr("value")).fadeIn();
        })
    .mouseout(function(){   
            $('#legend-tags').fadeOut();
        });
});

此选择返回3个元素,我想获得当前鼠标悬停的元素的属性。在这个测试代码中,我得到了#tag-video的属性,这是元素之一。

这是HTML:

<div id="legends">
  <span>TAGS</span>
  <div id="tag-motion" class="item tag-motion" value="motion"></div>
  <div id="tag-design" class="item tag-design" value="design"></div>
  <div id="tag-video" class="item tag-video" value="video"></div>
  <div id="legend-tags">legend</div>                
</div>

这是CSS:

#legends .item
{
    display: block;
    width: 27px;
    height: 27px;
    cursor: pointer;
    margin-bottom: 5px;    
}

#legend-tags
{
    display: none;
}

.tag-video
{
    background-image: url('../img/tag-video.svg');
}

.tag-video:hover
{
    background-image: url('../img/tag-video-over.svg');
}

.tag-design
{
    background-image: url('../img/tag-design.svg');
}

.tag-design:hover
{
    background-image: url('../img/tag-design-over.svg');
}

.tag-motion
{
    background-image: url('../img/tag-motion.svg');
}

.tag-motion:hover
{
    background-image: url('../img/tag-motion-over.svg');
}

2 个答案:

答案 0 :(得分:3)

您需要使用

$('#legend-tags').html($(this).attr("value")).fadeIn();

演示:Fiddle

在您的情况下,您使用了硬编码$('#tag-video')而不是您需要获取鼠标悬停的元素,此元素在悬停回调中可用作this变量。

注意:选择器$('#legends .iten')中有一个类型,它应该是$('#legends .item')

答案 1 :(得分:0)

这样的事情会起作用吗?

$("div.item").hover(function(){
    $('#legend-tags').html( $(this).attr("value") ).fadeIn();
});