Loading...
Обучение/Помощь новичкам | Время модального окна
Други. Подсобите. Мне надо чтобы модальное окно появлялось через 3 секунды (при входе), я сделал. А вот чтобы оно само закрылось (допустим через 5 секунд) я не могу сделать *facepalm* . Есть закрытие при клике, но мне надо именно авто закрытие (типо 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;
}
}
[xrystalll] , это да *facepalm* ты прав 100%.
Вот по этому я и спросил кто может подмогёт. Я бы ставил его на 3-5 секунд.
А если не подскажет ни кто, то воспользуюсь бегущей строкой
nefakt , в момент, когда окно появляется запускай интервал времени, не таймер а именно интервал, котрое по истечении времени закроет окно
Сибирский , То есть как-то так?
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)
Всё спасибо...... Понял объяснили нубу *polbu*
Онлайн: 4
Время:
Gen. 0.0753
(c) Bym.Guru 2010-2026