Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 03.12.2017
Сообщений: 90

Удаление класса по истечению времени

29.11.2020, 17:32. Показов 537. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте я - новичок в JS

Есть svg спрайтовая анимация. Запуск анимации происходит по клику на div, в котором лежит эта анимация, посредством добавления класса animate к этому div.

Проблема в том, что при повторном запуске, надо нажать на div 2 раза (1-й раз добавил класс, 2-й удалил класс, 3-й раз добавил класс), а надо чтобы анимация запускалась после каждого клика, и я думаю, что удаление класса должно происходить самостоятельно через setTimeout, но возникли проблемы с реализацией.

Буду очень благодарен людям умнее, кто поможет.

HTML5
1
<div id='figure' onclick="goAnimation();"></div>
JavaScript
1
2
3
4
5
6
7
8
9
    function goAnimation() {
        let figureElement = document.getElementById("figure");
        
        if (figureElement.classList.contains('animate')) {
            figureElement.classList.remove('animate');
        } else {
            figureElement.classList.add('animate');
        }
    }
CSS
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
#figure {
  background: url("https://s3-us-west-2.amazonaws.com/s.cdpn.io/57786/dog-walk.svg") no-repeat;
  width: 220px;
  height: 266px;
  border: 1px solid black;
}
 
.animate{
  transform: translate3D(200px, 50px, 0);
  animation: walk 0.78s steps(9) 1;
  transform: translateZ(0);
 
}
 
#figure:hover{
  cursor: pointer;
  border: 5px solid red;
}
 
@keyframes walk {
  100% { background-position: 0 -2376px; }
}
 
@media screen and ( max-width: 600px ) {
   #figure { transform: translate3D(40%, 100px, 0); }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.11.2020, 17:32
Ответы с готовыми решениями:

Удаление элемента по истечению времени
Здравствуйте , я пытаюсь сделать систему уведомлений , у меня есть контейнер &lt;div class=&quot;jumbotron&quot;...

По истечению времени выполнять действия
Всем привет!) Как сделать, чтобы по истечению 20 минут (или любого другого времени) выполнять какие либо действия? Например,...

По истечению заданного времени выдать сообщение с количеством правильных ответов
Добрый вечер Имеется код &lt;!DOCTYPE html&gt; &lt;html&gt; &lt;HEAD&gt; &lt;TITLE&gt;Закрытие окна через заданное время&lt;/TITLE&gt; &lt;link...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.11.2020, 17:32
Помогаю со студенческими работами здесь

Удаление строки из базы по истечению времени
Как сделать так что бы удалилась строка по истечению 24 ч или 1сутки база id|text| date| 1|Привет|2016-01-05 12:20:24| Нужно...

Создание временных данных в SQL с PHP или удаление данных из SQL по истечению времени
Пользователь вводит данные и они заносятся в SQL. Вопрос, как сделать, чтоб через, допустим, 10 мин удалялись эти данные? Добавлено...

Действия по истечению времени
Делаю лабу, во скрин с РадиоБатан все понятно, то не могу понять как сделать так что бы после того как пользователь выбрал дату и ввел...

Закрытие сайта по истечению времени
Приветствую вас друзья! Готовлю сайт для заказчика, доменное имя и хостинг будет его, хочу придумать &quot;защиту&quot; на случай...

Добавить год по истечению времени
Здравствуйте, подскажите пожалуйста как прибавить каждый раз один год к дате2 как только дата2 станет меньшей даты1 по истечению времени? ...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru