2

こんにちは皆さん、親 " li" を常に背景で強調表示したり、サブメニューにアクセスしたときにドロップダウンナビゲーションメニューの css からいくつかのプロパティを持つクラスを提供したりするにはどうすればよいですか? メニューのどのセクションをナビゲートしているかを示し、その背景はメニューが変更されるまで常に強調表示されたままになります。

HTML

<ul id="menu">
    <li><a href="#">About </a></li>
    <li><a href="#">Programmes</a>
        <ul class="secondLevel">
            <li><a onClick="ajaxCall();" href="">Undergraduate</a></li>
            <li><a href="#">Postgraduate</a></li>
        </ul>
    </li>
    <li><a href="#">Academics</a></li>
    <li><a href="#">Research</a></li>
    <li><a href="#">Facilities</a></li>
</ul>

CSS

#menu, #menu ul {
    margin: 0;
    padding: 0;
    list-style: none;
} #menu {
    width: 958px;
    /*margin: 60px auto;*/
    border: 1px solid #222;
    background-color: #111;
    background-image: linear-gradient(#444, #111);

box-shadow:
    0 1px 1px #777;
} #menu:before, #menu:after {
    content: "";
    display: table;
} #menu:after {
    clear: both;
} #menu {
    zoom: 1;
} #menu li {
    float: left;
    border-right: 1px solid #222;
    box-shadow: 1px 0 0 #444;
    position: relative;
} #menu a {
    float: left;
    padding: 11px 40px;
    color: #999;
    text-transform: uppercase;
    text-decoration: none;
    text-shadow: 0 1px 0 #000;
} #menu li:hover > a {
    color: #fafafa;
} * html #menu li a:hover { /* IE6 only */
    color: #fafafa;
} #menu ul {
    margin: 20px 0 0 0;
    _margin: 0; /*IE6 only*/
    opacity: 0;
    visibility: hidden;
    position: absolute;
    top: 38px;
    left: 0;
    right: -1px;
    z-index: 1000000;
    background: #444;
    background: linear-gradient(#444, #111);

box-shadow:
    0 -1px 0 rgba(255, 255, 255, .3);

transition:all
    .2s

ease-in-out;
} #menu li:hover > ul {
    opacity: 1;
    visibility: visible;
    margin: 0;
} #menu ul ul {
    top: 0;
    left: 150px;
    margin: 0 0 0 20px;
    _margin: 0; /*IE6 only*/
    box-shadow: -1px 0 0 rgba(255, 255, 255, .3);
} #menu ul li {
    float: none;
    display: block;
    border: 0;
    _line-height: 0; /*IE6 only*/
    box-shadow: 0 1px 0 #111, 0 2px 0 #666;
} #menu ul li:last-child {
    box-shadow: none;
} #menu ul a {
    padding: 10px;
    _height: 10px; /*IE6 only*/
    display: block;
    white-space: nowrap;
    float: none;
    text-transform: none;
} #menu ul a:hover {
    background-color: #000000;
} #menu ul li:first-child > a {
    /*border-radius: 3px 3px 0 0;*/
    padding: 11px 13px;
} #menu ul li:first-child > a:after {
    content: '';
    position: absolute;
    left: 40px;
    top: -6px;
} #menu ul ul li:first-child a:after {
    left: -6px;
    top: 50%;
    margin-top: -6px;
    border-left: 0;
} #menu ul li:first-child a:hover:after {
    border-bottom-color: #000;
} #menu ul ul li:first-child a:hover:after {
    border-right-color: #000;
    border-bottom-color: transparent;
} #menu ul li:last-child > a {
    /*border-radius: 0 0 3px 3px*/;
    padding: 11px 20px;
}

jsフィドル

4

2 に答える 2

7

.secondLevel要素にクリックイベントを追加するjQueryでそれを行うことができます:

$(document).ready(function(){
    $('.secondLevel').find('li').click(function(){

       //removing the previous selected menu state
       $('#menu').find('li.active').removeClass('active');

       //adding the state for this parent menu
       $(this).parents('li').addClass('active');
    });
});

activeメニューの状態を作成します。

#menu li.active{
    background: #ccddff;
}

実際の例: http://jsfiddle.net/L94N6/2/

アップデート

両方のリストで機能させるために、リスト クラスに応じて簡単な条件を追加できます。

$('#menu').find('li').click(function(){
   //removing the previous selected menu state
   $('#menu').find('li.active').removeClass('active');

    //is this element from the second level menu?
    if($(this).closest('ul').hasClass('secondLevel')){
         $(this).parents('li').addClass('active');

    //this is a parent element
    }else{
         $(this).addClass('active');
    }
});

実際の例: http://jsfiddle.net/L94N6/4/

于 2013-07-03T13:48:26.893 に答える
-1

私があなたの要求を正しく理解しているなら、追加するだけです

#menu li:hover {
    background: red;
}

これは、コンテンツがホバーされているときに、ドロップ ダウンの親の li のホバー状態が持続するためです。

于 2013-07-03T13:47:32.903 に答える