Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
-13 / 6 / 6
Регистрация: 04.08.2015
Сообщений: 622

Как управлять классами элемента li(html) в jQuery

27.08.2023, 19:17. Показов 938. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Для наглядности ссылка на статью про меню для сайта на html + CSS + jQuery с кодом http://dle-net.ru/index.php?newsid=979
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
$(document).ready(function () {
    $('#cssmenu li.has-sub > a').on('click', function(){
        $(this).removeAttr('href');
        var element = $(this).parent('li');
        if (element.hasClass('open')) {
            element.removeClass('open');
            element.find('li').removeClass('open');
            element.find('ul').slideUp();
        }
        else {
            element.addClass('open');
            element.children('ul').slideDown();
            element.siblings('li').children('ul').slideUp();
            element.siblings('li').removeClass('open');
            element.siblings('li').find('li').removeClass('open');
            element.siblings('li').find('ul').slideUp();
        }
    });
 
    $('#cssmenu>ul>li.has-sub>a').append('<span class="holder"></span>');
});
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<div id='cssmenu'>
    <ul>
       <li class='active'><a href='index.html'><span>Главная</span></a></li>
       <li class='has-sub'><a href='#'><span>Каталог</span></a>
          <ul>
             <li class='has-sub'><a href='#'><span>Смартфоны</span></a>
                <ul>
                   <li><a href='#'><span>Samsung</span></a></li>
                   <li><a href='#'><span>Sony</span></a></li>
                </ul>
             </li>
             <li class='has-sub'><a href='#'><span>Планшеты</span></a>
                <ul>
                   <li><a href='#'><span>Asus</span></a></li>
                   <li><a href='#'><span>Lenovo</span></a></li>
                </ul>
             </li>
          </ul>
       </li>
       <li><a href='#'><span>О магазине</span></a></li>
       <li><a href='#'><span>Контакты</span></a></li>
    </ul>
</div>
Реально у меня все меню находится в базе данных (названия пунктов меню, категории, линки на страницы)
Проблема в том, что на реальной странице если выбрать элемент субменю и перейти по ссылке на страницу, то меню перезагрузится и элемент субменю закроется.
Подскажите пожалуйста как сделать так, чтобы элемент субменю оставался открытым при переходе по ссылке в субменю и сам элемент субменю имел class='active'.
Что нужно добавить в код jQuery, HTML , чтобы решить эту задачку?

Добавлено через 3 часа 36 минут
Некоторые уточнения.
Как сделать так, чтобы has-sub открывалось не только при клике на #cssmenu li.has-sub > a но и при загрузке страницы, если, например значение поля из базы типа 'parent_id' не ноль.

Добавлено через 1 час 23 минуты
Это же вопрос подымался здесь https://stackoverflow.com/ques... -page-load
Но я не понял сути того, что предложили.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.08.2023, 19:17
Ответы с готовыми решениями:

Как из jQuery управлять доступом к TextBox на вэб-форме?
Здравствуйте! Подскажите, можно ли с помощью jQuery изменять свойства доступа (Enabled или ReadOnly) элемента управления TextBox на...

Мне надо послать html файл, как управлять кодировкой?
Мне надо послать html файл... я использую такой код: Set OLApp = New Outlook.Application Set myMessage = OLApp.CreateItem(olMailItem) ...

Изменить color одного элемента html если id второго элемента html сейчас в УРЛ-страницы
Доброго времени! Подскажите код JS позволяющий изменить color одного элемента html если id второго элемента html сейчас в УРЛ-страницы. ...

4
 Аватар для sad67man
2598 / 1502 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
28.08.2023, 16:53
VlGuvin, Делайте на стороне сервера при формировании html, добавляя необходимый класс.
0
-13 / 6 / 6
Регистрация: 04.08.2015
Сообщений: 622
31.08.2023, 10:52  [ТС]
Спасибо за мысль. Все крутится в Laravel и там есть возможность добавлять во вьюшку нужные классы. Никогда так не делал. Попробую...
0
-13 / 6 / 6
Регистрация: 04.08.2015
Сообщений: 622
31.08.2023, 20:04  [ТС]
Нужный параметр (класс "open") во вьюшку передаю. Но по ходу возник вопрос в открывании субменю. Вместе с передачей параметра нужно выполнить еще и команду
JavaScript
1
2
3
... 
 element.siblings('li').find('ul').slideUp();
...
Подскажите пожалуйста как это сделать. В данной ситуации кроме как кликом субменю не открывается.

Добавлено через 1 час 42 минуты
Вернее
JavaScript
1
element.children('ul').slideDown();
0
 Аватар для sad67man
2598 / 1502 / 689
Регистрация: 23.08.2015
Сообщений: 3,804
31.08.2023, 20:16
VlGuvin, Поставьте style="display: block;"
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
31.08.2023, 20:16
Помогаю со студенческими работами здесь

Как в jquery функции вывести форму в html
как с помощью jquery функции вывести форму в html или php

Как изменить через JS color одного элемента HTML если id второго элемента сейчас в URL?
Доброго времени суток! Подскажите ,пожалуйста, код JS с помощью которого можно изменить color одного элемента HTML если id второго...

Как добавить зависимость jquery в html во время дебагинга
есть код написанный для ИЕ. Нужно переделать с использованием jquery. Страница сейчас работает на серваке, доступа к нему нет -...

Как поменять позицию элемента в jQuery?
Мне нужно поменять позицию web-камеры на странице. Размер поменять могу, а вот позицию не знаю как. Какую функцию нужно для этого...

Как создать несколько html разметок в шаблоне и почему joomla не любит jquery
Ребят всем привет, занялся созданием шаблона, и сделал разметку в index.php шаблона, когда закончил шаблон, все вроде бы ничего ,но тут...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru