1

ドロップダウン メニューがあります (css のみ)

JSFIDDLE:

>>> jsfiddle <<<

HTML:

<div class="menu">
        <ul>
            <li><a href="#">Home</a></li>
            <li><a href="#">Tutorials</a>
                <ul>
                    <li><a href="#">Photoshop</a></li>
                    <li><a href="#">Illustrator</a></li>
                    <li><a href="#">Web Design</a>
                        <ul>
                            <li><a href="#">HTML</a>
                                <ul>
                                    <li><a href="#">HTML 4 and less</a>
                                        <ul>
                                            <li><a href="#">TEST 1</a></li>
                                            <li><a href="#">TEST 2</a></li>
                                            <li><a href="#">TEST 3</a></li>
                                        </ul>
                                    </li>
                                    <li><a href="#">HTML 5</a></li>
                                </ul>
                            </li>
                            <li><a href="#">CSS</a></li>
                        </ul>
                    </li>
                </ul>
            </li>
            <li><a href="#">Articles</a>
                <ul>
                    <li><a href="#">Web Design</a></li>
                    <li><a href="#">User Experience</a></li>
                </ul>
            </li>
            <li><a href="#">Inspiration</a></li>
        </ul>
    </div>

CSS:

.menu {
    margin: 100px auto; 
    text-align: center;
}

.menu ul ul {
    display: none;
}

.menu ul li:hover > ul {
    display: block;
white-space:nowrap;
}

.menu ul {
    background: #efefef; 
    padding: 0;
    list-style: none;
    position: relative;
    display: inline-table;
}
.menu ul:after {
    content: ""; 
    clear: both; 
    display: block;
}

.menu ul li {
    float: left;
}
.menu ul li:hover {
    background: blue;
}
.menu ul li:hover a {
    color: #fff;
}

.menu ul li a {
    display: block; 
    padding: 10px;
    color: #757575; 
    text-decoration: none;
}

.menu ul ul {
    background: green; 
    padding: 0;
    position: absolute; 
    top: 100%;
}
.menu ul ul li {
    float: none; 
    border-top: 1px solid #6b727c;
    border-bottom: 1px solid yellow; 
    position: relative;
}
.menu ul ul li a {
    padding: 10px;
    color: #fff;
    display: block; 
}   
.menu ul ul li a:hover {
    background: red;
}

.menu ul ul ul {
    position: absolute; 
    left: 100%; 
    top:0;
    padding: 0;
}

.menu ul ul ul li {
    float: none; 
    border-top: 1px solid #6b727c;
    border-bottom: 1px solid pink; 
    position: relative;
}

.menu ul ul ul li a { 
    padding: 10px;
    color: #fff;
    display: block; 
}

.menu ul ul ul li a:hover {
    background: red;
}

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

最後のサブメニューにあるように、それらは上位のメニューではありません。テキストを折り返して縮小します (最小幅)。

Q:

  1. それらを等しく(親と同じ幅)、テキストの折り返しなしにする方法は?
  2. 新しいサブメニューごとに新しいスタイルを作成する必要がないように、このメニュー (親、子、ul > li など) を単純化する方法

前もって感謝します。

4

1 に答える 1

0

これを試してください-これはChromeでうまく機能します:

* { white-space: nowrap; box-sizing: border-box; }

.menu {
    margin: 100px auto; 
    text-align: center;
}

/* ULs */

.menu ul {
    padding: 0;
    position: absolute; 
    display: none;
    background: green; 
    top: 0;
    position: absolute; 
    list-style: none;
}

.menu > ul {
    background: #efefef; 
    position: relative;
    display: inline-table;
}

.menu > ul > li > ul {
    top: 100%;
}

.menu li:hover > ul {
    display: block;
}

.menu ul ul ul {
    left: 100%; 
    border-left: 1px solid white;
    top: -1px;
}

/*LIs*/

.menu  li  {
    float: none;
    border-top: 1px solid #6b727c;
    border-bottom: 1px solid yellow; 
    position: relative;
}

.menu > ul > li {
    float: left !important;
    border: none;
}

.menu ul li:hover {
    background: blue;
}

/* As */

.menu a {
    display: block; 
    padding: 10px;
    color: #757575; 
    text-decoration: none;
}

.menu li:hover a {
    color: #fff;
}

.menu ul ul a:hover {
    background: red;
}

また、非常に多くのサブメニューを用意することは (ユーザーエクスペリエンスの観点から) 良い習慣ではないと考えてください。ユーザーをイライラさせない方法で、Web サイトの使用法に合わせて UI を再設計する必要があります。

于 2013-08-05T18:26:04.070 に答える