ie7 mouseleave时如何不隐藏子菜单?

发布于 2022-09-02 01:44:35 字数 1086 浏览 18 评论 0

导航菜单包括子菜单,当鼠标移入需要显示子菜单,鼠标移出则隐藏子菜单,但是在ie7下只要鼠标移出父级div时子菜单就消失了,鼠标永远无法移入到子菜单。
HTML如下

<div class="parentdiv">
    <span>父菜单1</span>
    <div class="submenu">
        <ul>
            <a href=""><li>子菜单1</li></a>
            <a href=""><li>子菜单2</li></a>
            <a href=""><li>子菜单3</li></a>
        </ul>
    </div>
</div>
<div class="parentdiv">
    <span>父菜单2</span>
    <div class="submenu">
        <ul>
            <a href=""><li>子菜单1</li></a>
            <a href=""><li>子菜单2</li></a>
            <a href=""><li>子菜单3</li></a>
        </ul>
    </div>
</div>

jQuery如下

$('.parentdiv').mouseenter(function(){
        $(this).children('.submenu').show();
}).mouseleave(function(event){
        $(this).children('.submenu').hide();
});

这样写在ie8 chrome下都可以正常显示,ie7不行,请问要如何解决?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

伴梦长久 2022-09-09 01:44:35

我在ie7下面测试也是可以的啊。
但对于你说的“只要鼠标移出父级div时子菜单就消失了,鼠标永远无法移入到子菜单。”这个问题,可以用setTimeout函数,延迟子菜单hide,然后在mouseenter事件里clearTimeout

吝吻 2022-09-09 01:44:35

有可能是因为定位的问题,你是否用了绝对定位,IE7有bug

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文