Выпадающее меню навигации отключено при уменьшении размера браузера

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

Редактировать: я сделал скрипку

А теперь мой код

HTML5

<nav>
    <nav class="nav-wrapper">
        <ul>
            <li><a href="index.html">Home</a>
            </li>
            <li><a href="appliances.html">Appliances</a>
            </li>
            <li><a href="Electronics/index.html">Electronics</a>

                <ul>
                    <li><a href="Electronics/computers.html">Computers</a></li>
                    <li><a href="Electronics/game_systems.html">Game Systems</a></li>
                    <li><a href="Electronics/televisions.html">Televisions</a></li>
                </ul>
            </li>
            <li><a href="Furniture/index.html">Furniture</a>

                <ul>
                    <li><a href="Furniture/bedroom.html">Bedroom</a></li>
                    <li><a href="Furniture/dining_room.html">Dining Room</a></li>
                    <li><a href="Furniture/living_room.html">Living Room</a></li>
                </ul>
            </li>
            <li><a href="location.html">Location</a>
            </li>
        </ul>
    </nav>
</nav>

CSS3

/*Default CSS*/
.main-header nav ul ul {
    display: none;
}

.main-header nav ul li:hover > ul {
    display: block;
}

.main-header nav ul {
    background: #efefef;
    background: linear-gradient(top, #efefef 0%, #bbbbbb 100%);
    background: -moz-linear-gradient(top, #efefef 0%, #bbbbbb 100%);
    background: -webkit-linear-gradient(top, #efefef 0%, #bbbbbb 100%);
    box-shadow: 0px 0px 9px rgba(0, 0, 0, 0.15);
    padding: 0 20px;
    border-radius: 10px;
    list-style: none;
    position: relative;
    display: inline-table;
}

.main-header nav ul:after {
    content:"";
    clear: both;
    display: block;
}

.main-header nav ul li {
    float: left;
}

.main-header nav ul li:hover {
    background: #4b545f;
    background: linear-gradient(top, #4f5964 0%, #5f6975 40%);
    background: -moz-linear-gradient(top, #4f5964 0%, #5f6975 40%);
    background: -webkit-linear-gradient(top, #4f5964 0%, #5f6975 40%);
}

.main-header nav ul li:hover a {
    color: #fff;
}

.main-header nav ul li a {
    display: block;
    padding: 25px 40px;
    color: #757575;
    text-decoration: none;
}

.main-header nav ul ul {
    background: #5f6975;
    border-radius: 0px;
    padding: 0;
    position: absolute;
    top: 100%;
}

.main-header nav ul ul li {
    float: none;
    border-top: 1px solid #6b727c;
    border-bottom: 1px solid #575f6a;
    position: relative;
}

.main-header nav ul ul li a {
    padding: 15px 40px;
    color: #fff;
}

.main-header nav ul ul li a:hover {
    background: #4b545f;
}

    /*Between 600px and 900px*/

.main-header nav ul {
    position: relative;
    margin: 0 auto;
    left: 10%;
}

.main-header nav ul ul {
    position: absolute;
    top: 100%;
}

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


person SecretWalrus    schedule 10.02.2014    source источник
comment
Вам нужно изучить медиа-запрос, developer.mozilla.org/ en-US/docs/Web/Guide/CSS/Media_queries   -  person Huangism    schedule 11.02.2014
comment
Я использую тег media, я просто не включил его в свой код, потому что не думал, что это важно. Я сказал, что размеры, над которыми я работаю, находятся между 600 и 900 пикселями, поэтому я подумал, что само собой разумеется, что я работаю в этом диапазоне.   -  person SecretWalrus    schedule 11.02.2014
comment
Пытался вставить ваш код в скрипку, не работает. Либо предоставьте больше кода, либо дайте ссылку на проблемную страницу.   -  person Huangism    schedule 11.02.2014
comment
Скрипка   -  person SecretWalrus    schedule 11.02.2014


Ответы (1)


Раскрывающийся список с абсолютным позиционированием должен находиться внутри контейнера с относительным позиционированием.

.main-header nav ul li {
    float: left;
    position: relative;
}

http://jsfiddle.net/UhEk4/2/

Очевидно, что нужно проделать больше работы, чтобы настроить позиции, но вы должны быть в состоянии взять это отсюда.

person Huangism    schedule 10.02.2014