javascript - CSS下拉菜单的奇怪行为

标签 javascript jquery html css drop-down-menu

请看这个link .将鼠标悬停在“菜单”上,将显示下拉菜单,然后暂停。现在我尝试将菜单更改为 TD 元素并将图像分配给此 TD 元素,当将鼠标悬停在该图像上时,它将更改图像并显示下拉菜单。请引用以下代码:

<html>
<head>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<style>
li.li_class{
    display: block;
}

ul.dropDown{
    margin:0px;
    padding:0px;
}
#clickable_div {width:166px; background-color:#9c9c9c;display:block;}

#nav_menu{width:166px; height:auto; background-color:#CCC;z-index: 99999; display: none;position: absolute;}

#wrap{ width:166px;}
</style>
</head>

<body>
    <table>
        <tr>
            <td><img src="images/ori_12.png">
            </td>
            <td id='testable'>
                <div id='wrap'>
                    <img src="images/ori_14.png">
                    <div id="nav_menu">
                        <ul class="dropDown">
                            <li class="li_class"><img src="images/ori_12.png"></li>
                            <li class="li_class"><img src="images/ori_14.png"></li>
                            <li class="li_class"><img src="images/ori_15.png"></li>
                            <li class="li_class"><img src="images/ori_16.png"></li>
                        </ul>
                    </div>
                </div>
            </td>
        </tr>
        <tr>
            <td>
                abc
            </td>
            <td>
                def
            </td>
        </tr>
    </table>

</body>
<script>
        $('#testable img')
        .mouseenter(function () {
            this.src = this.src.replace('/ori_', '/hover_');
            $('#nav_menu').stop(true, true).slideDown();
        })
        .mouseleave(function () {
            this.src = this.src.replace('/hover_', '/ori_');
            $('#nav_menu').stop(true, true).slideUp();
        });



        $('#nav_menu li img')
        .mouseover(function () {
            this.src = this.src.replace('/ori_', '/hover_');
        })
        .mouseout(function () {
            this.src = this.src.replace('/hover_', '/ori_');
        });

    </script>
</html> 

当我将鼠标悬停在图像上时,图像会被替换并且下拉菜单会向下滑动,但是,我无法将鼠标悬停在下拉列表项上,因为下拉菜单会立即向上滑动。

最佳答案

尝试

 $('#testable  #wrap').mouseenter(function (e) {
     var anc = $(this).children('img').get(0);
     anc.src = anc.src.replace('/ori_', '/hover_');
     $('#nav_menu').stop(true, true).slideDown();
 }).mouseleave(function (e) {
     var anc = $(this).children('img').get(0);
     anc.src = anc.src.replace('/hover_', '/ori_');
     $('#nav_menu').stop(true, true).slideUp();
 });

Fiddle

当您将鼠标悬停在图像外以悬停在菜单中时,会触发 mouseout。因此,在包装器上应用悬停事件。如果此包装器不合适,请创建一个包装器来包装菜单及其图像,并对其应用悬停效果。

关于javascript - CSS下拉菜单的奇怪行为,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19019122/

相关文章:

javascript - 使用javascript顺序循环遍历一个数组和另一个数组

javascript - 仅在模态 Pane 中保持制表符

javascript - 使用 Ajax 在 Gridview 更新后显示工具提示

javascript - 从数据特征添加 Google Maps InfoWindow 产生错误 : "b.get is not a function"

javascript - 通过字符串从设置事件获取事件对象

javascript - 难以使用 Javascript 切换媒体查询

javascript - 执行某种淡入淡出的功能所涉及的机制/算法是什么?

android - 向下滚动时触摸/单击区域在响应菜单中移位

javascript - 如何使用 DOM 更改表格内单行的背景颜色

javascript - 尝试使用 GreaseMonkey 提交表单,但页面停止工作