5 / 5 / 0
Регистрация: 19.02.2013
Сообщений: 55

Скрыть div при клике вне элемента

06.07.2013, 17:48. Показов 7883. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток. Для показа div'а и его скрытия при клике вне его границ использую вот такой код:
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
$(function(){
    $('#callback a').click(function(){
        $( ".all-screen-call" ).fadeIn( 'slow' );
        var $message = $('.all-screen-call');
        var firstClick = true;
        $(document).bind('click.myEvent', function(e) {
            if (!firstClick && $(e.target).closest('.all-screen-call').length == 0) {
            $message.fadeOut( "slow" );
            $(document).unbind('click.myEvent');
        }
        firstClick = false;
        });
    });
    $('#all-screen-callback-title a').click(function(){
        $( ".all-screen-call" ).fadeOut( 'slow' );
    });
});
Так же имеется ссылка на самом div'е, которая его скрывает. Но если закрыть div с ее помощью, то при последующем клике для показа, div просто появляется на секунду и тут же скрывается. Я так понимаю это происходит из-за переменной firstClick, но различные манипуляции с ней мне не помогли. Как исправить данную проблему?
1
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.07.2013, 17:48
Ответы с готовыми решениями:

Скрыть <DIV> при клике на динамическом баннере, находящемся в данном <DIV>
Добрый день. Есть &lt;li&gt; , в нем находится динамический баннер . Необходимо, чтобы при клике по баннеру происходил переход по ссылке,...

Показать/скрыть меню при клике вне его области
&lt;button type=&quot;button&quot; id=&quot;toggle&quot;&gt;Меню&lt;/button&gt; &lt;ul class=&quot;nav&quot; id=&quot;nav&quot;&gt; &lt;li&gt;&lt;a href=&quot;#&quot;&gt;Home&lt;/a&gt;&lt;/li&gt; &lt;li&gt;&lt;a...

Показать/скрыть блок div при клике
Добрый день! Пробую сделать штуку на jQuery, чтобы при щелчке мыши по надписи &quot;Показать/скрыть форму заявки&quot; появлялся блок с формой,...

3
 Аватар для Soldado
901 / 833 / 198
Регистрация: 28.06.2012
Сообщений: 1,607
Записей в блоге: 4
06.07.2013, 20:42
Для ссылки
JavaScript
1
2
3
4
$('#all-screen-callback-title a').click(function(ev){
ev.stopPropagation() ;// клик только по верхнему элементу - ссылке, ниже клик не распостраняется
        $( ".all-screen-call" ).fadeOut( 'slow' );
    });
1
5 / 5 / 0
Регистрация: 19.02.2013
Сообщений: 55
07.07.2013, 09:33  [ТС]
Soldado, Ваш вариант не работает. Оказывается нужно так, может кому пригодится.

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
$(function(){
    $('#callback a').click(function(){
        $( ".all-screen-call" ).fadeIn( 'slow' );
        var $message = $('.all-screen-call');
        var firstClick = true;
        $(document).bind('click.myEvent', function(e) {
            if (!firstClick && $(e.target).closest('#all-screen-callback').length == 0) {
                $message.fadeOut( "slow" );
                $(document).unbind('click.myEvent');
            }
            firstClick = false;
        });
    });
    $('#all-screen-callback-title a').click(function(){
        $(document).unbind('click.myEvent');
        $( ".all-screen-call" ).fadeOut( 'slow' );
    });
});
1
1 / 1 / 0
Регистрация: 19.02.2015
Сообщений: 1
19.02.2015, 16:13
Hrommi, cпасибо огромное!
Вставить строку
JavaScript
1
$(document).unbind("click.myEvent");
при обработке нажатия на кнопку внутри появившегося div'a помогло мне решить аналогичную проблему.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.02.2015, 16:13
Помогаю со студенческими работами здесь

Как скрыть все DIV кроме заданного ID при клике?
Здравствуйте, на странице есть меню-фильтр из ссылок вида: &lt;a href=&quot;#nomer1&quot;&gt;Фильтр1&lt;/a&gt; &lt;a...

Сокрытие элемента при клике вне него
Здравствуйте. Имеется такой код $(function(){ //Живой поиск $('.who').bind(&quot;change keyup input click&quot;, function()...

Закрыть div при клике вне его
День добрый, может есть у кого соображения по поводу: есть кнопка и уже имеющийся Javascript код. По клику на кнопке под ней появляется...

Скрыть div при клике в другом месте
&lt;script type=&quot;text/javascript&quot;&gt; $(function(){ $(&quot;#search&quot;).keyup(function(){ var search = $(&quot;#search&quot;).val(); $.ajax({ ...

Как скрыть блок div по клику вне самого блока?
Всем привет! Нашёл вот такой код: document.onclick = function(ev) { myDiv = document.getElementById('myDivId'); if...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru