Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
27 / 41 / 13
Регистрация: 15.05.2013
Сообщений: 1,313

Вертикальное выпадающее меню

18.08.2015, 18:19. Показов 1662. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста привести вертикальное меню к рабочему состоянию. Уже два дня не могу настроить правильную работу менюшки.
Имеется меню справа, и при наведении на подменю, вложенные пункты меню "иногда" выходят за пределы почему-то.
И подскажите, как настроить, чтобы отступ сверху у вложенных менюшек соответствовал отступу их родителю, т.е. чтобы вложенные ul соответствовали отступу сверху их родителю li. Я уже перепробовал и offset().top и parent().top и .css('top'), но так и не добился результата.
Ссылка на песочницу
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<div class="menu">
    <div class="icon-menu" title="Menu">
        <span>Menu</span>
    </div>
    <ul>
        <li class="mini-bg"></li>
        <li class="active"><a href="index.html">Home</a></li>
        <li><a href="#">About</a>
            <ul>
                <li><a href="">Quisque nulla</a></li>
                <li><a href="">Vestibulum libero</a></li>
                <li><a href="">Vivamus eget nibh</a>
                    <ul>
                        <li><a href="">Quisque nulla</a></li>
                        <li><a href="">Vestibulum libero</a></li>
                        <li><a href="">Vivamus eget nibh</a>
                    </ul>
                </li>
            </ul>
        </li>
        <li><a href="#">What We Do</a></li>
        <li><a href="#">Menu</a></li>
        <li><a href="#">Contacts</a></li>
    </ul>
</div>
 
<div class="test"></div>
CSS
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
a, abbr, acronym, address, applet, article, aside, audio, b, blockquote, big, body, center, canvas, caption, cite, code, command, datalist, dd, del, details, dfn, dl, div, dt, em, embed, fieldset, figcaption, figure, font, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, keygen, label, legend, li, meter, nav, object, ol, output, p, pre, progress, q, s, samp, section, small, span, source, strike, strong, sub, sup, table, tbody, tfoot, thead, th, tr, tdvideo, tt, u, ul, var {
    background: transparent;
    border: 0 none;
    font-size: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: top;
}
 
ol, ul {
    list-style: none;
}
 
        .menu {
            position: fixed;
            display: block;
            /*width: 100%;*/
            z-index: 10;
            width: auto;
            height: auto;
        }
        .icon-menu {
            position: fixed;
            top: 2em;
            right: 50px;
            cursor: pointer;
            width: 4em;
            height: 4em;
            background: gray;
            z-index: 1000;
            /*text-align: center;*/
            -webkit-border-radius: 4px;
            -moz-border-radius: 4px;
            -ms-border-radius: 4px;
            -o-border-radius: 4px;
            border-radius: 4px;
            -webkit-transition: background .2s linear, box-shadow .2s linear, right .3s linear, top .3s linear, transform .3s linear;
            -moz-transition: background .2s linear, box-shadow .2s linear, right .3s linear, top .3s linear, transform .3s linear;
            -ms-transition: background .2s linear, box-shadow .2s linear, right .3s linear, top .3s linear, transform .3s linear;
            -o-transition: background .2s linear, box-shadow .2s linear, right .3s linear, top .3s linear, transform .3s linear;
            transition: background .2s linear, box-shadow .2s linear, right .3s linear, top .3s linear, transform .3s linear;
            -webkit-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -moz-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -ms-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -o-box-shadow: 0 0 10px rgba(0,0,0,.5);
            box-shadow: 0 0 10px rgba(0,0,0,.5);
        }
        .icon-menu:hover {
            -webkit-box-shadow: 0 0 15px rgba(0,0,0,.8);
            -moz-box-shadow: 0 0 15px rgba(0,0,0,.8);
            -ms-box-shadow: 0 0 15px rgba(0,0,0,.8);
            -o-box-shadow: 0 0 15px rgba(0,0,0,.8);
            box-shadow: 0 0 15px rgba(0,0,0,.8);
            background: #b4b4b4;
        }
        .menu-top {
            -webkit-transform: scale(0.5);
            -moz-transform: scale(0.5);
            -ms-transform: scale(0.5);
            -o-transform: scale(0.5);
            transform: scale(0.5);
            top: -.7em;
            right: .5em;
        }
        .backgr {
            background: black;
        }
        .icon-menu span,
        .icon-menu span:before,
        .icon-menu span:after {
            -webkit-border-radius: 2px;
            -moz-border-radius: 2px;
            -ms-border-radius: 2px;
            -o-border-radius: 2px;
            border-radius: 2px;
        }
        .icon-menu span {
            position: absolute;
            /*text-align: center;*/
            top: 45%;
            width: 80%;
            height: 10%;
            background: white;
            display: inline-block;
            text-indent: 2000px;
            margin-left: 10%;
        }
        .icon-menu span::before {
            position: absolute;
            top: -230%;
            content: "";
            text-align: center;
            width: 100%;
            height: 100%;
            background: white;
            display: block;
        }
        .icon-menu span::after {
            position: absolute;
            bottom: -230%;
            content: "";
            text-align: center;
            width: 100%;
            height: 100%;
            background: white;
            display: block;
        }
        .menu ul {
            /*display: none;*/
            position: fixed;
            top: 0;
            right: -20%;
            width: 20%;
            height: 100%;
            /*-webkit-transition: right .3s linear;*/
            -moz-transition: right .3s linear;
            /*-ms-transition: right .3s linear;*/
            /*-o-transition: right .3s linear;*/
            transition: right .3s linear;
            display: block;
            background: white;
            border-left: 1px solid gray;
            /*z-index: 20;*/
            opacity: 1;
            /*overflow: hidden;*/
        }
        .ul-show {
            right: 0 !important;
            display: block !important;
        }
        .menu ul li {
            /*position: relative;*/
            height: 2.5em;
            -webkit-transition: background .3s linear;
            -moz-transition: background .3s linear;
            -ms-transition: background .3s linear;
            -o-transition: background .3s linear;
            transition: background .3s linear;
            /*position: relative;*/
            z-index: 10;
        }
        .mini-bg {
            background: #5b5b5b;
        }
        .menu ul li:hover:not(.mini-bg) {
            background: #d67f7f;
        }
        .menu ul:not(ul ul) li:hover a {
            color: white;
        }
        .menu ul li:hover a ul {
            z-index: -1 !important;
        }
        .menu ul li a {
            font: 1em "Open Sans", sans-serif;
            font-weight: 300;
            color: #a95858;
            text-decoration: none;
            margin-left: 15%;
        }
        .menu .active {
            background: #a95858;
        }
        .menu .active a {
            color: white;
        }
        .show {
            /*right: 0 !important;*/
            top: 0;
            -webkit-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -moz-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -ms-box-shadow: 0 0 10px rgba(0,0,0,.5);
            -o-box-shadow: 0 0 10px rgba(0,0,0,.5);
            box-shadow: 0 0 10px rgba(0,0,0,.5);
            display: block;
        }
        .menu ul ul {
            transition: right .3s linear, left .3s linear;
            display: none;
            z-index: -1 !important;
            height: auto;
            background: gray;
            border-left: 1px solid gray;
            opacity: .99;
            width: 20%;
            -webkit-border-radius: 4px;
            -moz-border-radius: 4px;
            -ms-border-radius: 4px;
            -o-border-radius: 4px;
            border-radius: 4px;
            /*position: fixed;*/
        }
 
        .test {
            position: fixed;
            top: 55%;
            left: 10%;
            font: 1em sans-serif;
            color: green;
        }
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
(function( $ ){
    $.fn.mymenu = function(direction) {
        var direct = arguments.length > 0 ? direction : "vertical";
        var opened = false,
            $ulFirst = $('.menu ul:first'),
            dispWidth = $(document).width(),
            twenty = dispWidth * 20 / 100,
            right = 0,
            nav = 0,
            zindex=10;
 
        //Клик по иконке меню при ещё не раскрытой менюшке
        $('.icon-menu').click(function () {
            $('.menu ul').find('ul').hide();
            $(this).toggleClass('menu-top');
            $ulFirst.toggleClass('ul-show');
        });
 
        //Обработчик событий наведения на пункт меню li > a
        $('.menu li').on('mouseenter', function(){
            $this = $(this);
            var $ulka = $this.find('ul:first');
            if($ulka.length){
                right += 20;
                nav++;
                $ulka.css('top', $this.position().top);
                $('.test').html($ulka.parent().html()+$ulka.parent().offset().top+' $this.position().top='+$this.position().top);
                $ulka.show().css({
                    'top': $this.position().top+'px',
                    'right': right+'%',
                    'z-index': zindex
                });
                zindex--;
            }
        }).on('mouseleave', function(){
            $ulka = $(this).find('ul');
            if($ulka.length) {
                $this = $(this);
                nav--;
                right -= 20;
                $ulka.css({
                    'top': $this.css('top')+'px',
                    'right': right+'%'
                });
                zindex++;
            }
        });
 
        //Скрыть окно меню при нажатии на любом месте вне окна
        $(document).click(function (event) {
            if (!$(event.target).is('.menu ul') && $(event.target).closest('.menu').length == 0) {
                if($('.icon-menu').hasClass('menu-top')) {
                    $('.menu ul').find('ul').hide();
                    $('.icon-menu').toggleClass('menu-top');
                    $ulFirst.toggleClass('ul-show');
                    opened = false;
                    right=0;
                }
            }
        });
 
    };//$.fn
 
})(jQuery);
 
 
$(document).ready(function(){
    $('.menu').mymenu();
})
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.08.2015, 18:19
Ответы с готовыми решениями:

Вертикальное меню
Доброго время суток форумчяни, подскажите пожалуйста как можно реализовать вот такое меню заранее спасибо!

Многоуровневое вертикальное меню
Всем привет. Нужно создать многоуровневое вертикальное меню. В JS и JQuery не силен, поэтому, при решении задачи использовал готовые...

Вертикальное и горизонтальное меню не сворачивается
Имеется горизонтальное меню, в котором вложено ещё 2 подменю. 1-е подменю открывается вертикально, 2-е гор-но, сбоку верт-го. Проблема...

9
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
18.08.2015, 23:07
вот то, что у меня получилось, но это надо ещё работать, там я баги нашёл

Добавлено через 32 минуты
вот ещё одна версия, те баги я исправил, но пришлось использовать ваши переменные не поназначению, за это прошу прощения
1
27 / 41 / 13
Регистрация: 15.05.2013
Сообщений: 1,313
18.08.2015, 23:24  [ТС]
Цитата Сообщение от BANO Посмотреть сообщение
вот ещё одна версия, те баги я исправил, но пришлось использовать ваши переменные не поназначению, за это прошу прощения
та мне главное чтобы работало! Благодарю
Кстати а что значит эта строчка: off('mouseleave.closingF') ?
что такое closingF ?
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
18.08.2015, 23:44
phpk, честно говоря применял в первый раз, но объяснить смогу
это "namespase"
если посмотреть то там сначала есть строка
JavaScript
1
$this.on('mouseleave.closingF', function (e) {
а off отключает, то есть снимает эвент

короче про эту фичу тут прочитал, где-то в конце
1
27 / 41 / 13
Регистрация: 15.05.2013
Сообщений: 1,313
19.08.2015, 01:38  [ТС]
теперь что-то не получается сделать обработчик события, который следит за открытым меню, и если убрали курсор с открытого меню, то меню должно закрыться.
Как нужно правильно задать условие все, кроме .icon-menu ?
потому-что этот обработчик срабатывает и при закрытом меню!
JavaScript
1
2
3
4
5
6
7
$('.menu').not('.icon-menu').on('mouseleave', function(){
            //if($(this).hasClass('icon-menu')) {
                $('.menu ul').find('ul').hide();
                $('.icon-menu').toggleClass('menu-top');
                $ulFirst.toggleClass('ul-show');
            //}
        });
http://jsfiddle.net/gqe2vtk3/8/

Добавлено через 13 минут
с обработчиком события закрытия меню вроде получилось
JavaScript
1
2
3
4
5
6
7
8
$('.menu').on('mouseleave', function(e){
            $targ = $(e.target || e.srcElement);
            if (!$targ.is('.icon-menu')) {
                $('.menu ul').find('ul').hide();
                $('.icon-menu').toggleClass('menu-top');
                $ulFirst.toggleClass('ul-show');
            }
        });
посмотрел в соседней теме

Добавлено через 34 минуты
Кстати, теперь не помешало бы сделать задержку при открытии и закрытии меню, потому-что как-то быстро закрывается при случайном выходе за границы менюшки.
Подскажите пожалуйста, как к данному коду добавить задержку открытия-закрытия?

Добавлено через 33 минуты
Я уже пытался применять setTimeout, но из-за задержек прорисовки анимации, координаты подменю иногда вычисляются неправильно, отрываются от основного меню и могут уйти в минус пикселей
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
19.08.2015, 10:06
Лучший ответ Сообщение было отмечено phpk как решение

Решение

phpk, надеюсь я вас понял и сделал так, как надо
1
27 / 41 / 13
Регистрация: 15.05.2013
Сообщений: 1,313
19.08.2015, 11:09  [ТС]
BANO, я очень благодарен за вашу помошь! Мне очень помогла ваша подсказка в моих начинаниях, так-как опыта у меня ещё мало.
Кстати я так и не понял, почему при вычислении отступа сверху(top) не дало результата использование методов offset().top и parent().top и .css('top') ? С чем это может быть связано?

Добавлено через 5 минут
Кстати для вложенных пунктов меню также хотелось бы сделать задержку анимации, как вы сделали с закрытием меню.
А .fadeIn(300) немного не то, что нужно.
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
19.08.2015, 11:32
phpk, надеюсь я вас понял и сделал так, как надо
Цитата Сообщение от phpk Посмотреть сообщение
offset().top и parent().top и .css('top')
.css("top") - то что указанно в стиле, обычно в пикселях
.parent().top - вообще не помню такого свойства
.offset().top - по идее это и есть то, что я сделал, но вариант jquery
1
27 / 41 / 13
Регистрация: 15.05.2013
Сообщений: 1,313
19.08.2015, 11:36  [ТС]
так а как же сделать для вложенных пунктов задержку анимации?
0
Ренегат
Эксперт HTML/CSS
 Аватар для BANO
1740 / 1085 / 386
Регистрация: 06.08.2014
Сообщений: 5,203
Записей в блоге: 1
19.08.2015, 13:37
phpk, это кстати можно сделать с помощью css анимации, там есть задержка
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
19.08.2015, 13:37
Помогаю со студенческими работами здесь

Выпадающее меню
Делаю выпадающее меню: при щелчке по кнопке меню раскрывается, если еще раз щелкнуть меню сворачивается...но есть проблема, нужно сделать...

Выпадающее меню
Здравствуйте, как задать скорость выпадающего меню и чтобы меню при наведении курсора не просто появлялясь, а с определенной скоростью...

Выпадающее меню
Приветствую. Имеется вот такое меню: Оно формируется из массива: foreach($arResult as $arItem){ ...

Выпадающее меню
$('#header-link-title').click(function () { if ($(this).hasClass('active')) { $('#mobile-link-top').animate({ ...

Выпадающее меню
Привет всем. Сегодня пытался найти скрипт выпадающего меню, но столкнулся с такой проблемой. Дело в том, что во всех скриптах, если начнешь...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru