1

尝试使用 jQuery 的悬停来显示/隐藏 ul 项目以提供下拉效果。

这是jQuery。忽略警报功能

$(document).ready(function () { 

    $('ul.drop li').hover(
        function () {
            alert("asa");
            //show its submenu
            var isVisible = $(this).next('ui').is(':visible');
            alert("dvData is " + isVisible);
            var isHidden = $(this).next('ui').is(':hidden');
            alert("dvData is " + isHidden);

            $(this).next('ul').css({visibility: "visible", display: ""});

        }, 
        function () {
            //hide its submenu
            $(this).next('ul').css({visibility: "hidden", display: ""});
        }
    );

});

这是jsp页面

<ul class="drop">
<li><a href="#">Main</a></li>
<li>Reporting
 <ul >
    <li><a href="#" target="_blank">Magellan Reports</a></li>
    <li><a href=""/>"  target="_blank">Script Reports</a></li>
 </ul>

<li><a href="<c:url value="#"/>"   target="_blank">CMS</a></li>
<li><a href="<c:url value="#"/>"  target="_blank">Operations</a></li>
</ul>

这是CSS

ul#nav {padding-left:16px;background-image:url(../images/buehne_5_intra.gif)}
clear {clear:both}
ul.drop a {color:#87A7CE;line-height:14px;display:block;text-decoration: none;
background-repeat:no-repeat;background-image:url(../images/diagonale_hauptnavigation.gif);background-position:right;
    height:10px;padding-right:22px; float:left;}
ul.drop, ul.drop li, ul.drop ul { list-style: none; margin: 0; padding: 0; background: #039;
color: #fff;}
ul.drop { position: relative; z-index: 597; float: left; }
ul.drop li { float: left; line-height: 1.0em; vertical-align: middle; zoom: 1; padding: 5px 10px; }
ul.drop li ul { visibility: hidden; position: absolute; top: 100%; left: 20px; z-index: 598; width: 150px; margin-left:50px;}
ul.drop ul a {color:#87A7CE;line-height:14px;display:block;text-decoration: none;height:10px;padding-left:10px; float:left;background-image:none;}
ul.drop ul li { float: none; }
ul.drop ul ul { top: -2px; left: 100%; }
.drop img{width:22px;height:24px;background-color:#039;margin-left:-20px;vertical-align:top}

我 cud 只用 css 完成了它,但是一些必需的、长的和损坏的 css 文件不允许我这样做..请帮助 jQuery。

4

1 回答 1

1

next()寻找下一个兄弟姐妹,它不匹配,因为您没有<ul>兄弟姐妹来触发<li>. 相反,您想要寻找孩子,因此请尝试children()找到匹配的孩子。将您的 JS 修改为以下内容:

$('ul.drop li').hover(
    function () {
        $(this).children('ul').css({visibility: "visible", display: ""});
    }, 
    function () {
        $(this).children('ul').css({visibility: "hidden", display: ""});
    }
);

您可以在此处查看演示 - http://jsfiddle.net/GoranMottram/Uxj2B/3/ - CSS 看起来需要一些工作,但至少 JS 可以工作。

于 2013-02-19T16:57:07.007 回答