Обучение/Помощь новичкам | Время модального окна
Тема закрыта by
DELETED
Причина: Нашёл решение. Спс за советы
Причина: Нашёл решение. Спс за советы
DELETED
Автор
12 марта 2018, в 13:11
Delete
. Есть закрытие при клике, но мне надо именно авто закрытие (типо time aut). Кто подскажет что не так в коде?
Вот сам код ↓
HTML
<a href="#open" title="Закрыть" class="alles">x</a> <!--Кнопка Закрыть. Якорная ссылка-->
<div id="open" class="tele">
<hr style="margin-top: 23px;">
<div class="modal">
Контент внутри окна
</div>
</div>
CSS
/* Затемнение экрана */
.tele {
position: fixed;
top: 0;/* Растягиваем по краям экрана */
right: 0;
bottom: 0;
left: 0;
background: rgba(0,0,0,0.2); /* Затемнение */
z-index: 99999;/* Поверх всех слоёв */
pointer-events: none;/* Запрет мыши */
display: block;
animation: main-titl 3s linear; /* Плавное появление */
}
/* Применяем к идентификатору */
.tele:target {
display: none;
pointer-events: auto; /* Восстанавливаем мышь */
}
/* Окно */
.modal{
width: 25%;
position: fixed;
top: 30%;
left: 30%;
right: 30%;
padding: 10px;
pointer-events: auto; /* Восстанавливаем доступ к ссылкам */
text-align: center;
line-height: 25px;
border-radius: 3px;
background: #fff;
box-shadow: 1px 2px 3px rgba(0, 0, 0, 0.4),
-1px 0 2px rgba(0, 0, 0, 0.4);
}
/* Кнопка Закрыть */
.alles {
position: absolute;
top: 5px;
right: 5px;
width: 30px;
background: #FFF;
color: #888;
line-height: 18px;
text-align: center;
text-decoration: none;
font-family: Arial;
border: 2px colid #FF5037;
border-radius: 2px;
animation: main-close 3s linear; /* Кнопка появляется вместе с затемнением */
}
.alles:hover {
background: #FF5037;
}
.alles:active {
background: rgba(0, 0, 0, 0.01);
}
.alles:visited {
background: #fff;
}
@keyframes main-titl {
0% {
transform: translateY(6em);
opacity: 0;
}
95% {
opacity: 0;
}
100% {
transform: translateY(0);
opacity: 1;
}
}
@keyframes main-close {
0% {
transform: translateY(6em);
opacity: 0;
}
95% {
opacity: 0;
}
100% {
transform: translateY(0);
opacity: 1;
}
}
DELETED
Автор
12 марта 2018, в 13:35
Delete
ты прав 100%. Вот по этому я и спросил кто может подмогёт. Я бы ставил его на 3-5 секунд.
А если не подскажет ни кто, то воспользуюсь бегущей строкой
nefakt , в момент, когда окно появляется запускай интервал времени, не таймер а именно интервал, котрое по истечении времени закроет окно
DELETED
Автор
12 марта 2018, в 13:43
Delete
animation: main-titl 3s linear; time-aut 3s;
Или я чет опять туплю
ну у тебя модальное окно должно запускаться и закрываться по функциям, предположим это open_modal и close_modal когда срабатывает open_modal запускаешь setInterval, которая по истечении заданного времени вызовет close_modal
setInterval
Синтаксис
intervalID = window.setInterval(func|code, delay)
Аргументы
func|code
Функция или строка кода для выполнения
delay
Интервал в миллисекундах, т.е 1000 это 1 секунда
Описание, примеры
В отличие от метода setTimeout, setInterval выполняет код много раз, через равные промежутки времени, пока не будет остановлен при помощи clearInterval.
В каком виде указывать первый параметр - разницы нет.
При указании строки кода - динамически создается функция func с телом code.
Следующие два вызова почти одинаковы:
setInterval('alert("прошла секунда")', 1000)
function sec() {
alert("прошла секунда")
}
setInterval(sec, 1000)
Но более правильным считается объявление функции в явном виде, например так:
setInterval(function() { alert(...) }, 1000)
Синтаксис
intervalID = window.setInterval(func|code, delay)
Аргументы
func|code
Функция или строка кода для выполнения
delay
Интервал в миллисекундах, т.е 1000 это 1 секунда
Описание, примеры
В отличие от метода setTimeout, setInterval выполняет код много раз, через равные промежутки времени, пока не будет остановлен при помощи clearInterval.
В каком виде указывать первый параметр - разницы нет.
При указании строки кода - динамически создается функция func с телом code.
Следующие два вызова почти одинаковы:
setInterval('alert("прошла секунда")', 1000)
function sec() {
alert("прошла секунда")
}
setInterval(sec, 1000)
Но более правильным считается объявление функции в явном виде, например так:
setInterval(function() { alert(...) }, 1000)
DELETED
Автор
12 марта 2018, в 13:58
Delete