Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 06.04.2015
Сообщений: 51

Закрыть <DIV>.</DIV> на веб-странице щелчком по закрывающей кнопке

27.07.2016, 11:15. Показов 3369. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код:
HTML5
1
2
3
4
5
<div class="menu-container">
 <div class="block-keep-ratio" style="background:#fff;border-top:12px solid #55aaff;padding:18px">
<p><span style="color:#66d52f;border-left:3px solid #66d52f;padding-left:10px"><b>К СВЕДЕНИЮ!</b></span>$MESSAGE$</p>
 </div> 
 </div>
Как можно сделать так, чтобы пользователь мог его просто закрыть?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.07.2016, 11:15
Ответы с готовыми решениями:

Закрыть JTabbedPane щелчком на кнопке размещенной на вкладке
Пишу простой текстовый редактор. Сделал возможность редактирования нескольких файлов одновременно. Добавить файл можно, а вот удалить...

Вычисление выражения с=(a+b mod a*4+b div a) div 2-a div 160
Пожалуйста, посмотрите на код, уввжаемые! нужно вычислить такое выражение: с=(a+b mod a*4+b div a) div 2-a div 160 У меня неверно...

CSS!? Div в div'e, как не потерять позиции css внутреннего div'a при изменении размера браузера?
вот когда изменяю размер браузера, то внутренний div не хочет изменяться вместе с контейнером, а контейнер изменяется? .container{ ...

9
 Аватар для AmateR62
118 / 118 / 87
Регистрация: 24.02.2014
Сообщений: 404
27.07.2016, 11:36
А где у вас закрывающая кнопка в коде?) Рисуете кнопку, например с классом "close-menu-container" и пишите обработчик:

JavaScript
1
2
3
4
5
$(function(){
  $('.close-menu-container').click(function() {
    $('.menu-container').css('display', 'none');
  });
});
0
0 / 0 / 0
Регистрация: 06.04.2015
Сообщений: 51
27.07.2016, 12:56  [ТС]
AmateR62, спасибо большое. А можно ли сделать так, чтобы браузер запоминал в куках, что окно было закрыто и при перезагрузке страницы снова не открывал их?

Код обработал немного:

HTML5
1
2
3
4
5
<div class="menu-container" id="close1">
 <div class="block-keep-ratio" style="background:#fff;border-top:12px solid #55aaff;padding:18px">
<p><span style="color:#ff2a55;border-left:3px solid #ff2a55;padding-left:10px"><b>СРОЧНОЕ ОБЪЯВЛЕНИЕ!</b><img src="/images/close.png" align="right" class="close-container1" title="Закрыть"/></span>$MESSAGE$</p>
 </div> 
 </div>
JavaScript
1
2
3
4
5
$(function(){
  $('.close-container1').click(function() {
    $('#close1').css('display', 'none');
  });
});
0
 Аватар для AmateR62
118 / 118 / 87
Регистрация: 24.02.2014
Сообщений: 404
27.07.2016, 13:14
Цитата Сообщение от Rustambeg Посмотреть сообщение
А можно ли сделать так, чтобы браузер запоминал в куках, что окно было закрыто и при перезагрузке страницы снова не открывал их?
Можно. Для jQuery есть плагин работы с куками - https://github.com/carhartl/jquery-cookie. При клике по кнопке устанавливаете куку, например:

JavaScript
1
2
3
4
  $('.close-container1').click(function() {
    $('#close1').css('display', 'none');
    $.cookie('view_container', 'true');
  });
и проверять при загрузке страница

JavaScript
1
2
3
if ( $.cookie('view_container')!=null ) {
  $('#close1').css('display', 'none'); // если кука есть, то окошко скрываем
}
как то так
0
0 / 0 / 0
Регистрация: 06.04.2015
Сообщений: 51
27.07.2016, 21:03  [ТС]
AmateR62, спасибо за неоценимую помощь, но я не силён в jQuery и JavaScript, и возникли некоторые проблемы в компоновке кодов. Если первый поставил как надо, то со вторым проблемы - не работает. Вообще не закрывается теперь. Или закрывается, но при перезагрузке страницы открывается снова.
Как их скомпоновать вместе?
0
 Аватар для AmateR62
118 / 118 / 87
Регистрация: 24.02.2014
Сообщений: 404
27.07.2016, 21:59
Вы плагин подключили?

Код будет примерно такой:

$(function(){
if ( $.cookie('view_container')!=null ) {
$('#close1').css('display', 'none'); // если кука есть, то окошко скрываем
}

$('.close-container1').click(function() {
$('#close1').css('display', 'none');
$.cookie('view_container', 'true');
});
});
0
0 / 0 / 0
Регистрация: 06.04.2015
Сообщений: 51
27.07.2016, 22:19  [ТС]
AmateR62, я окончательно запутался. От JS далёк, может, скоро и нужно уже изучать его, но пока...

В общем у меня такой код (тот, первый):

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<script type="text/javascript">
 $(function(){
 $('.close-container1').click(function() {
 $('#close1').css('display', 'none');
 $.cookie('view_container', 'true'); 
 });
});
 $(function(){
 $('.close-container2').click(function() {
 $('#close2').css('display', 'none');
 $.cookie('view_container', 'true');
 });
});
 $(function(){
 $('.close-container3').click(function() {
 $('#close3').css('display', 'none');
 $.cookie('view_container', 'true');
 });
});
      </script>
Если я добавляю под ним или в него:
JavaScript
1
2
3
4
5
6
7
8
9
10
$(function(){
if ( $.cookie('view_container')!=null ) {
$('#close1').css('display', 'none'); // если кука есть, то окошко скрываем
}
 
$('.close-container1').click(function() {
$('#close1').css('display', 'none');
$.cookie('view_container', 'true');
});
});
, то всё равно при перезагрузке всё остаётся по-прежнему.
0
 Аватар для AmateR62
118 / 118 / 87
Регистрация: 24.02.2014
Сообщений: 404
27.07.2016, 23:29
Да, моя ошибка - не посмотрел плагин куков, а там уже все по другому. У вас несколько окон? Они должны закрываться разными кнопками? Просто вы на 1 куку вешаете сразу три окна, поэтому если вы одно скроете, то потом, при перезагрузке страницы все три не будут показываться. А так, правильный код должен быть такой:
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
$(function(){
  // проверяем куку при загрузке страницы
  // если кука есть, то скрываем три? окошка
  // и вот тут не понятно - у вас у окошек id #close1, #close2 и #close3?
  // пусть так... для примера сойдет
  if ( Cookies.get('view_container')!=null ) {
    $('#close1, #close2, #close3').css('display', 'none');
  }
 
 
 $('.close-container1').click(function() {
   $('#close1').css('display', 'none');
   Cookies.set('view_container', 'true'); 
 });
 
  $('.close-container2').click(function() {
    $('#close2').css('display', 'none');
    Cookies.set('view_container', 'true');
  });
 
  $('.close-container3').click(function() {
    $('#close3').css('display', 'none');
    Cookies.set('view_container', 'true');
  });
 
});
Вот накидал примерчик - http://codepen.io/AmateR/pen/qNKYBk
Нажмете кнопку close и блок скроется, при перезагрузке страницы он тоже скрыт, если нажмете кнопку reset кука сбрасывается и окошко снова показывается

P.S. вы так и не ответили на вопрос - плагин для работы куков вы смогли подключить?
0
0 / 0 / 0
Регистрация: 06.04.2015
Сообщений: 51
28.07.2016, 00:12  [ТС]
Да, подключил вот так: <script src="/js/jquery.cookie.js"></script> (перед закрывающим HEAD) - скачал и загрузил в корневую папку.
Вставил код, но теперь вообще перестало реагировать, даже не закрывается.
Эх, ладно, что уж... Придётся отказаться от этой идеи...
0
 Аватар для AmateR62
118 / 118 / 87
Регистрация: 24.02.2014
Сообщений: 404
28.07.2016, 00:14
Цитата Сообщение от Rustambeg Посмотреть сообщение
Эх, ладно, что уж... Придётся отказаться от этой идеи...
Зачем отказываться? Мне кажется вам надо просто навести порядок в коде )) А для начала посмотрите - какую ошибку валит в консоли?)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.07.2016, 00:14
Помогаю со студенческими работами здесь

<div> перекрывает 2 других <div>. Не отображается <div>
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML 1.0 Strict//EN&quot; &quot;http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd&quot;&gt; &lt;html...

Резиновый размер div'a, размер div'a в зависимости от расположения div'ов в нем
Надо чтобы div &quot;telo&quot; растягивался в зависимости от дивов которые находятся в нем. тоесть должен быть черный квадрат в котором по углам...

Закрыть окно DIV
Добрый день, подскажите пожалуйста как закрыть DIV окно ? &lt;script&gt; function showSpoiler(obj){var inner =...

Открыть/закрыть DIV по нажатию
Мучаюсь уже несколько часов, нужно: 1) При нажатии на картинку чтобы открылся скрытый блок DIV. 2) При нажатии на открывшийся блок он...

Открыть закрыть несколько div
Здравствуйте. Имеется код. &lt;script type=&quot;text/javascript&quot;&gt; var show; function viewdiv(id){ param=document.getElementById(id); ...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru