Задать вопрос
@Ba1tazarr
Начинающий фронтенд разработчик

Как добавить класс в зависимости от ширины экрана?

Есть блок с 5 элементами в два ряда (три сверху и два с низу). Нужно чтобы при адаптиве это все прекращалось в слайдер (карусель) и показывалось по одному с перелистыванием. Подключил slick и думаю при изменении разрешения экрана добавлять нужному блоку класс, который инициализирую в slick. Как сделать это через JS?
  • Вопрос задан
  • 196 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
mizutsune
@mizutsune
I will live forever in the flame of your eyes.
Вам не класс нужно переключать на элементе, а включать и выключать слайдер, при достижении определенного брейкпоинта. Всё это дело можно легко решить с помощью matchMedia.

Вот небольшой пример:

const slider = $(".slider").slick({
     centerMode: true,
     slidesToShow: 4
});

const breakpoint = window.matchMedia("(max-width: 992px)");

const breakpointChecker = () => {
   if (breakpoint.matches) {
      slider.slick('init');
   } else {
      slider.slick('destroy');
   }
};

breakpoint.addEventListener("change", breakpointChecker);
breakpointChecker();


А вот для дополнительной стилизации контейнера, уже можно использовать медиа запросы в CSS.
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
noder_ss
@noder_ss
Линуксоид-энтузиаст и SQL разработчик
Простой пример с цветом. Пользователь, у которого ширина меньше 1000, будет видеть красный цвет.
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <p class="text">Текст</p>
</body>
<style>
    .class{
        color: red;
    }
</style>
<script>
    let text = document.querySelector('.text')
    if(document.documentElement.clientWidth < 1000){
        text.classList.add('class')
    }
</script>
</html>
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы