0

我正在尝试使用 jQuery 创建一个菜单,就像当用户将鼠标悬停在一个元素上时,菜单会显示并在用户将鼠标移开时隐藏。

我的html代码:

<div class="span8 img">
   <img src="http://farm4.staticflickr.com/3198/2978120072_ca00381e08.jpg" alt="" width="550px" height="368px">
   <div class="like-box">Like</div> 
</div>

CSS:

.like-box {
    display: block;
    background: rgba(255, 255, 255, .9);
    padding: 15px;
    position: absolute;
    left: -1px;
    width: 94%;
    bottom: -1px;
    display: none;
}

Javascript:

$('.img').mouseover(function() {
        $(this).parent().siblings('.like-box').css('display', 'block');
        $(this).parent().siblings('.like-box').mouseleave(function() {
        $(this).css('display', 'none');
        })
    });

但这似乎不起作用。

4

2 回答 2

2

mouseleave将事件绑定在imgmouseover外,因为在mouseover内绑定事件,like-box每次都绑定mouseleave事件,不好也没必要。

$('.like-box').mouseleave(function() {
    $(this).css('display', 'none');
})
$('img').mouseover(function() {
    $(this)  // this point to img
      .next('.like-box')  // point to like-box
      .css('display', 'block');       
});

演示

笔记:

  • $('.img')应该是$('img')因为您的图像没有调用类img.选择器用于访问类。阅读选择器类选择器
于 2012-05-30T06:23:44.033 回答
1

你的问题在这里:

$(this).parent().siblings('.like-box')

$(this)is img, the parent()is div.span8.img, and the siblings()are...none。

尝试:

$(this).next('.like-box')
于 2012-05-30T06:25:33.253 回答