在我的css代码中,first-child无法正常工作

时间:2012-02-20 10:01:37

标签: css css3 html-lists css-selectors

我在使用第一个孩子时遇到了问题

我有以下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 个答案:

答案 0 :(得分:3)

使用>你可以防止风格影响孙子,所以试着改变这个

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 :(得分:1)

你的代码太乱了......你可以在没有<ul><li>的情况下复制相同的内容..这里是home/products菜单的一小部分。你找到了你的主页解决方案在这里..

http://jsfiddle.net/NMrMN/

你可以根据你的特定需要应用必要的css ..但是,使用div来实现这一点可以让你更自由地如何将元素放在页面上..所以,这是我的解决方案,我认为是你的问题..