尝试使用 jQuery 创建菜单,但我的代码不起作用

Trying to create a menu with jQuery but my code isn't working

本文关键字:我的 代码 不起作用 菜单 创建 jQuery      更新时间:2023-09-26

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

我的网页代码:

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

但这似乎行不通。

mouseleave事件绑定img鼠标悬停,因为鼠标悬停中的绑定事件,每次都将mouseLeave事件绑定到like-box,这是不好的,也是不必要的。

$('.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 的类,.选择器用于访问类。 阅读有关选择器和类选择器的信息

你的问题在这里:

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

$(this)imgparent()div.span8.imgsiblings()是...没有。

尝试:

$(this).next('.like-box')