выпадающее меню только css - ширина подменю (без обтекания текстом)

У меня есть выпадающее меню (только 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 и т. д.), чтобы мне не нужно было создавать новый стиль для каждого нового подменю

Заранее спасибо.


person Ing. Michal Hudak    schedule 05.08.2013    source источник
comment
Как примечание, если у вас есть подменю с 4 уровнями глубины, это может быть неоптимальным с точки зрения взаимодействия с пользователем.   -  person frenchie    schedule 05.08.2013
comment
это только на крайний случай, потому что некоторые пользователи достаточно глупы, чтобы делать 4-уровневые подменю ;)   -  person Ing. Michal Hudak    schedule 05.08.2013


Ответы (1)


Попробуйте это — это отлично работает в 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;
}

Кроме того, учтите, что это не очень хорошая практика (с точки зрения пользователя) иметь так много подменю. Вы должны попытаться перепроектировать свой пользовательский интерфейс, чтобы он соответствовал использованию вашего веб-сайта таким образом, чтобы не разочаровывать пользователя.

person EZLearner    schedule 05.08.2013