|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
||||||
Закрыть блок при клике по любому месту на странице31.10.2012, 21:25. Показов 15328. Ответов 14
Метки нет (Все метки)
Привет!
Есть список, который открывается при нажатии на некоторую ссылку, также и закрывается при повторном нажатии. Нужно еще, чтобы блок закрывался при нажатии по любому месту страницы, кроме самого блока. Как такое сделать?
Пример - меню этого форума.
0
|
||||||
| 31.10.2012, 21:25 | |
|
Ответы с готовыми решениями:
14
При клике в браузере по любому месту открываются левые сайты
Сделать, чтобы при клике на кнопке, блок #cont исчез, а при повторном клике блок #cont появился |
|
Почетный модератор
16844 / 6724 / 880
Регистрация: 12.06.2012
Сообщений: 19,967
|
|||||||
| 31.10.2012, 21:28 | |||||||
1
|
|||||||
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
|
| 31.10.2012, 21:31 [ТС] | |
|
KOPOJI, когда пишу body, блок не появляется вабще, даже при клике по ссылке, т.к., сама ссылка внутри body.
нет ли у тя готового решения, задача распространенная, но почему то в сети не нашел разумного решения
0
|
|
|
|
|
| 31.10.2012, 21:46 | |
|
Когда кликаешь по чему-то там чтобы блок раскрылся, то клик происходит и по body, так как кликнутый элемент тоже находится в body и получается, что блок открывается и одновременно закрывается. Есть возможность предотвратить этот, так называемый, bibbling-еффект, чтобы клик касался только верхнего элемента. Для этого используют stopPropagation()
Вот демо-страница, там всё видно
1
|
|
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
|
| 31.10.2012, 23:11 [ТС] | |
|
Soldado, все отлично, но вот тока блок закрывается и при клике по блоку (
че делать? Добавлено через 3 минуты + при повторном клике по ссылке блок не закрывается
0
|
|
|
|
|||
| 01.11.2012, 02:26 | |||
Если проблема всё же существует, то давайте полный код или сами используйте .toggle() (есть недостаток - если откроем, а потом закроем кликом по body, то для нового открытия прийдётся кликать дважды) или .click (рекомендую), но тогда анализируйте свойство display. Как на этом сайте
1
|
|||
|
2436 / 1115 / 312
Регистрация: 23.06.2011
Сообщений: 3,531
|
||||||
| 01.11.2012, 06:16 | ||||||
|
подправляем под реальный поиск конкретного элемента
1
|
||||||
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
||||||||||||
| 01.11.2012, 09:06 [ТС] | ||||||||||||
|
Показываю код
0
|
||||||||||||
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
||||||||||||||||||||||||||
| 01.11.2012, 16:25 [ТС] | ||||||||||||||||||||||||||
|
вот хтмл (весь не привожу, большой список)
вот js
0
|
||||||||||||||||||||||||||
|
|
||||||
| 01.11.2012, 16:32 | ||||||
|
Live устаревший метод от него предполагается отказаться в будущем, используйте on, вот так работает:
Это переделан код из Вашего поста №8, со строки 10.
1
|
||||||
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
||||
| 01.11.2012, 16:47 [ТС] | ||||
![]() Добавлено через 20 секунд кстати, у меня работает и без этого при вставке последнего предложенного метода, блок перестал исчезать при клике по любому месту страницы. при клике на открывающий div теперь блок закрывается
0
|
||||
|
|
|
| 01.11.2012, 16:51 | |
|
У меня в последней опере не работает без ob.stopPropagation(); в части кода где live на on заменил.
В общем так. Всё что мне дали объединил, лишь заменил live на on и залил на demo-страницу . Что работает не так как Вы хотите?
1
|
|
|
960 / 801 / 85
Регистрация: 21.07.2010
Сообщений: 3,522
|
||
| 01.11.2012, 17:18 [ТС] | ||
Спасибо большое Добавлено через 5 минут замену Live на On стоит везде сделать?
0
|
||
|
|
||||||
| 01.11.2012, 17:23 | ||||||
|
Рад что помог.
На счёт упрощения кода. Вы получаете атрибут id у элемента, а затем из него формируете атрибут id элемента ul к которому обращаетесь. Верно? Но если посмотреть на html-код, то заметите что относительно кликнутого элемента необходимый Вам ul является следующим, а значит можно обойтись более простым способом доступа к нему. И код // Открытие списка <ul> (Клик по div'у "Выбрать регион") может упростится на несколько строчек:
1
|
||||||
| 01.11.2012, 17:23 | |
|
Помогаю со студенческими работами здесь
15
Открыть закрыть блок при нажатии по ссылке и закрыть его при нажатии вне этого блока при клике вне виджета закрыть его
При клике по окну браузера закрыть чекбокс Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
|
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
|
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
|
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
|
|
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2.
Данный документ берёт данные из другого нетипового документа. . .
|
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
|
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: реализовать программный контроль на предмет проведения документа. . .
|
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача:
1. Реализовать контроль заполнения реквизита. . .
|