@DeniSidorenko

Возможно ли добавить плавность в данной ситуаций?

Привет, сделал простой аккордеон.

<div class='item'>
<div class='submenu'></div>
</div>


Логика простая, submenu скрыто, при клике на item, добавляется класс active и в стилях item.active{ display block}. Только нету совсем анимации. Возможно ли как то тут ее добавить? Либо стоит изменить сили как то?
  • Вопрос задан
  • 258 просмотров
Пригласить эксперта
Ответы на вопрос 4
@vladimir_html
дык на jq есть slideToggle)
Ответ написан
Комментировать
webinar
@webinar
Учим yii: https://youtu.be/-WRMlGHLgRg
используйте keyframes
Ответ написан
Комментировать
SvyatYa
@SvyatYa
FrontEnd developer
Сделай:
.submenu {
  max-height: 0;
  overflow: hidden;
  transition: 0.2s (вот это и отвечает за анимацию)
}
.active {
  max-height: 30px;
  transition: 0.2s
}


Проблема этого метода, что надо заранее знать высоту контента внутри.
Иначе если поставить max-height больший чем свой контент, то можно заметить задержки в анимации.
Никаких jq в анимациях не надо использовать.
Ответ написан
Комментировать
mdss
@mdss
добавьте функцию анимации. Например
@keyframes fadeIn {
from {opacity:0}
to {opacity:1}
}

использование
.submenu--active {
display:block;
animation:fadeIn .5s;
}
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы