문제

I am trying to create a layered menu with css. My problem as you can see, is that when I go to the 3rd UL, that the second UL loses its styling (white font color). What am I missing in my css to keep the second UL at a white font with the light blue BG like I did with the top UL?

http://codepen.io/anon/pen/xhKrC

Thanks

Blanks out the 2nd layer menu item

<nav id="menu">
<ul>
    <li><a>Users</a></li>
    <li>
        <a>Applications</a>
        <ul>
            <li>
                <a>Application 1</a>
                <ul>
                    <li><a>Users</a></li>
                    <li><a>Roles</a></li>
                    <li><a>Groups</a></li>
                </ul>
            </li>
        </ul>
    </li>
</ul>
</nav>

    nav {
    float: left;
    background: #142c56;
    color: #ffffff;
    height: 45px;
}

    nav ul li:hover > ul {
        display: block;
    }


nav ul {
    box-shadow: 0px 0px 9px rgba(0,0,0,0.15);
    position: relative;
    display: inline-block;
    list-style: none;
    white-space: nowrap;
    margin-left: 20px;
    box-sizing: content-box;
}
    nav ul:after {
        content: ""; clear: both; display: block;
    }

    nav ul li {
        float: left;
    }
        nav ul li:hover {
            background: #425677;
            color: #ffffff;
        }

        nav ul li a {
            display: block;
            padding: 14px 33px;
            margin-top: 1px;
            cursor: pointer;
            text-decoration: none;
        }       

    nav ul ul {
        background: #ffffff;
        position: absolute; 
        top: 100%;
        margin-left: 0px;
        display: none;
    }
        nav ul ul li {
            float: none;
            position: relative;
        }
            nav ul ul li a {
                padding: 15px 40px;
                color: #425677;
                margin-top: 0px;
            }
                nav ul ul li a:hover {
                background: #425677;
                color: #ffffff;
                }

    nav ul ul ul {
        position: absolute; left: 100%; top:0;
    }
도움이 되었습니까?

해결책

You can just change line 75 in the CSS of that Pen to nav ul li:hover > a - The link overrides the color of the text, that's why you'd need to over-specify this rule.

다른 팁

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
    display: block;
}
body {
    line-height: 1;
    font-family: "Segoe UI", Segoe, Tahoma, Verdana, Helvetica, Sans-Serif
}
ol, ul {
    list-style: none; 
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}


nav {
        float: left;
        background: #142c56;
        color: #ffffff;
        height: 45px;
    }

        nav ul li:hover > ul {
            display: block;
        }


    nav ul {
        box-shadow: 0px 0px 9px rgba(0,0,0,0.15);
        position: relative;
        display: inline-block;
        list-style: none;
        white-space: nowrap;
        margin-left: 20px;
        box-sizing: content-box;
    }
        nav ul:after {
            content: ""; clear: both; display: block;
        }

        nav ul li {
            float: left;
        }
            nav ul li:hover {
                background: #425677;
                color: #ffffff;
            }

            nav ul li a {
                display: block;
                padding: 14px 33px;
                margin-top: 1px;
                cursor: pointer;
                text-decoration: none;
            }       

        nav ul ul {
            background: #ffffff;
            position: absolute; 
            top: 100%;
            margin-left: 0px;
            display: none;
        }
            nav ul ul li {
                float: none;
                position: relative;
            }
                nav ul ul li a {
                    padding: 15px 40px;
                    margin-top: 0px;
                }
                    nav ul ul li a:hover {
                    background: #ff2800;
                    color: #ffffff;
                    }

        nav ul ul ul {
            position: absolute; left: 100%; top:0;
        }

try this code :)

라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top