Задать вопрос
@Niki21212

Как сделать показ разного количества блоков при разной ширине на js?

Сейчас у меня при ширине 768px показаны 6 блоков, остальные срыты, есть кнопка которая показывает все блоки. Нужно, чтобы при ширине 1120px показывало 8 блоков. Как это сделать на js?

function openbox(logo) {
   display = document.getElementById(logo).style.display;
  if(display=='none'){
      document.getElementById("button").innerText = "Скрыть";  
      document.getElementById(logo).style.display='flex';
   }else{
      document.getElementById("button").innerText = "Показать все";
      document.getElementById(logo).style.display='none';
     }  
 };


<section></section>
        <section></section>
        <section></section>
        <section></section>
        <section></section>
        <section></section>

        <div id="logo">

        <section></section>
        <section></section>
        <section></section>
        <section></section>
        <section></section>
        <section></section>

        </div>
    
    
    <button class="slider-main__button-read-more" id="button" onclick="openbox('logo');  return false">Показать все</button>


#logo {
display: none
}
  • Вопрос задан
  • 102 просмотра
Подписаться 1 Простой 1 комментарий
Пригласить эксперта
Ответы на вопрос 1
yuchiko
@yuchiko
Сделайте для них общий родитель и при загрузке DOM элементов посчитайте ширину окна.
А затем пройдитесь по children этого родителя и при нужном index === 6 или 8 начните добавлять hidden.
https://developer.mozilla.org/ru/docs/Web/API/Pare...

Если хотите и при смене размера экрана подписаться:
https://developer.mozilla.org/ru/docs/Web/API/Wind...
то ту же функцию можно вызывать и тут
Ответ написан
Комментировать
Ваш ответ на вопрос

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

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 17:50
7000 руб./за проект
18 дек. 2024, в 17:26
5000 руб./за проект
18 дек. 2024, в 17:23
1500 руб./за проект