первый ребенок не работает должным образом в моем коде CSS - PullRequest
1 голос
/ 20 февраля 2012

У меня проблема с использованием первого ребенка

У меня есть следующий HTML-код для создания меню с первым и вторым уровнями

<ul id="navMenu"  >
    <li class="parent"><a href="index.html">Home</a> 
    </li>
    <li class="parent"><a href=".html">Products</a>
        <ul ><li><a href="">Software</a>
            <ul>
                <li><a href="">Product 1</a></li>
                <li><a href="">Product 2</a></li>
                <li><a href="">Product 3</a></li>
            </ul>
            </li>
            <li><a href="">Hardware</a>
                <ul>
                    <li><a href="">Product 1</a></li>
                    <li><a href="">Product 2</a></li>
                </ul>
            </li>
        </ul>
    </li>
</ul>

и следующим css

#menuContainer{
    float: right;
}

ul#navMenu{
    margin: 25px 0 0;
    list-style: none outside none;
}

ul#navMenu li{
    float: left;
    margin: 0 0 0 0px;
    position: relative;
    z-index: 999;
}

ul#navMenu li a{
    display: block;
    padding: 5px 0px;
    font-size: 13px;
    line-height: 12px;
    background: transparent;
    color: #444;

    -webkit-transition: background-color 0.1s linear, color 0.1s linear;
    -moz-transition: background-color 0.1s linear, color 0.1s linear;
}


ul#navMenu li.parent a{
    padding-right: 23px;
    background-color: transparent;
    background-repeat: no-repeat;
    background-position: right top;
    font-family: "Lucida Grande", Tahoma, Arial, sans-serif;
    text-transform: uppercase;


}

ul#navMenu li a:hover, ul#navMenu li.current a{
    color: #CB0167 ;
    text-decoration: none;
    font-family: "Lucida Grande", Tahoma, Arial, sans-serif;

}

ul#navMenu li.parent a:hover, ul#navMenu li.current.parent a{
    background-position: right bottom;
}


/* - -- --- ---- Sub-Menu ---- --- -- - */

ul#navMenu li.parent ul{
    display: none;
    position: absolute;
    top: 25px;
    left: 0;
    width: 160px;
    margin: 0;
    padding: 0px 0 0;
    list-style: none outside none;
    overflow: visible;
    z-index: 99;
    border-top: 1px solid #eee;

}
.noJs ul#navMenu li.parent:hover ul{
    display: block;
}

ul#navMenu li.parent ul li{
    float: none;
    margin: 0;
    padding: 0;

}

ul#navMenu li.parent ul li a{
    display: block;
    padding: 7px 10px;
    color: #444;
    background: #fff;
    font-size: 11px;
    border-right: 1px solid #eee;
    border-left: 1px solid #eee;
    text-transform: none;
    background-image: url('../img/dots_menu.png');
    background-repeat: no-repeat;
}


ul#navMenu li.parent ul li:first-child a{   
    background-image: none;


    }

ul#navMenu li.parent ul li:first-child a:hover{ 
    background-image: none;
    }

ul#navMenu li.parent ul li:last-child a{    
    box-shadow: 0 1px 0 rgba(0,0,0,0.05);
    border-bottom: 1px solid #eee;  
}
ul#navMenu li.parent ul li a:hover{
    color: #CB0167 !important;
    background: #fefefe;
    background-image: url('../img/dots_menu.png');
    background-repeat: no-repeat;   
}
/* - -- --- ---- Second Level Sub-Menu ---- --- -- - */

ul#navMenu li.parent ul li ul{
    display: none;
    position: absolute;
    top: -1px;
    left: 159px;
    width: 160px;
    margin: 0;
    padding: 0 0 0 0px;
    border-top: 1px solid #eee;

}

ul#navMenu li.parent ul li ul.leftMenu{
    left: -168px;
    padding: 0 10px 0 0;
}

.noJs ul#navMenu li.parent:hover ul li ul{
    display: none;
}

.noJs ul#navMenu li.parent ul li:hover ul{
    display: block;
}

ul#navMenu li.parent ul li ul li:first-child a{ 
    background-image: none;

}
ul#navMenu li.parent ul li ul li:first-child a:hover{   
    background-image: none;

}

Меню продукта - это именно то, что мне нужно, и аппаратное меню, но программное обеспечение меню не работает, есть идеи, как это исправить ??

Большое спасибо:)

Ответы [ 2 ]

3 голосов
/ 20 февраля 2012

с помощью > вы можете предотвратить влияние стиля на стиль внука, поэтому попробуйте изменить это

ul#navMenu li.parent ul li:first-child  a{  

к этому

ul#navMenu li.parent ul li:first-child > a{ 

также

ul#navMenu li.parent ul li:first-child  a:hover{    

с этим

ul#navMenu li.parent ul li:first-child > a:hover{   
1 голос
/ 20 февраля 2012

ваш код слишком испорчен ... вы можете повторить то же самое без <ul> и <li> .. вот небольшой фрагмент вашего меню home/products .. home, где вы найдете свое решение здесь ..

http://jsfiddle.net/NMrMN/

Вы можете применить необходимые CSS для своих конкретных потребностей ... но использование div для достижения этой цели даст вам больше свободы в размещении элементов на странице ... так чтоэто мое решение того, что я считаю твоей проблемой ..

...