Рубрики
Разработка

Как быстро ограничить количество выводимых постов в WordPress?

Чтобы ограничить количество выводимых постов в WordPress в пределах одного цикла нужно сделать следующее:

 $the_query = new WP_Query( array(
'posts_per_page' => 2
));

Все, больше ничего другого делать не надо.

Другие статьи о разработке: тут.

Рубрики
Разработка

Модальное окно на JS быстро

Модальное окно – маленькое окошко, которое всплывает, чтобы сказать о чем то важном. Сложно ли сделать модальное окно без Bootstrap? Попробуем разобраться.

Куда вставить в DOM?

Обычно, я помещаю его перед закрывающим тэгом body.

 
      <div class="modal" id="modal"></div>
    </body>
  </html>

В основном по причине стилей. Намного легче позиционировать модальное окно на CSS, когда вы имеете дело со слоем обертывающим весь body, чем с неизвестным набором родительских элементов, у которого потенциально может быть свое позиционирование.

Центрирование

Вот один из моих любимых трюков, когда вы можете отцентровать и вертикально и горизонтально, без знания высоты и ширины.


.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

Это очень удобно так как, открытое модальное окно обычно должно находится прямо по центру, несмотря на ширину. Высота, тем более скорее всего изменится, так как она зависит от контента внутри.

Position – fixed?

Обратите внимание мы использовали position: fixed; чтобы пользователи могли иметь возможность скроллить вниз, в то время как открытое модальное окно оставалась всегда посередине. Я считаю, в целом, что значение fixed уже можно смело использовать, даже на мобильных устройствах. Однако, если вам нужно учесть старые телефоны, попробуйте заменить значением absolute.

Разберемся с шириной

На больших экранах, типичное открытое модальное окно не только отцентровано, но и ограниченно по ширине.


.modal {
  width: 600px;
}

Однако, есть такие экраны, которые меньше 600px в ширину. Чтобы исправить ситуацию добавим максимальную ширину.


.modal {
  width: 600px;
  max-width: 100%;
}

Высота

Задавать высотку еще более ответственное занятие. Мы знаем, что контент имеет свойство меняться. Плюс, техника центрирования через transform радостно обрезает края, без появления скролл-бара. Установка максимальной высоты обезопасит нас второй раз.


.modal {
  height: 400px;
  max-height: 100%;
}

Overflow

После того как мы разобрались с высотой, пришло время заняться свойством overflow. Распространенно использовать overflow значение, прямо в .modal, однако, есть две проблемы с этим:

  • Мы можем захотеть использовать элементы, которые не должны скролиться
  • Overflow обрежет тень, которую мы будем использовать.

Я бы предложил использовать внутренний контейнер:


<div class="modal" id="modal">
  <!-- не скролиться -->
   <div class="modal-guts">
     <!--- скролиться -->
   </div>
</div>

Учитывая, что у нас будет контент который нужно скролить, нам нужно задать высоту. Есть несколько вариантов. Вот один из них:

 


.modal-guts {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
/* отступы */
  padding: 20px 50px 20px 20px;
/* разрешим скролить */
  overflow: auto;
}

Кнопки

Идея использования модальных окон в том, чтобы принудить выполнить какое-либо действие, перед тем, как что-нибудь будет сделано. Сделать кнопку закрытия окна видной в любом состоянии кажется не плохой идеей.


<div class="modal" id="modal">
  <!-- не скролиться -->
  <button class="class-button" id="close-button">Закрыть</button>
  <div class="modal-guts">
  <!--- скролиться -->
  </div>
</div>

Разберемся с затемнением

Обычное модальное окно делают с полностью затемняющимся фоном. Это полезно по нескольким причинам:

  • оно может затемнить остальной экран
  • может предотвратить клики/взаимодействие с контентом вокруг модального окна
  • может использоваться, как гигантская кнопка закрытия

Типичный пример использования:


<div class="modal" id="modal">
  <!-- Модалка -->
 </div>

<div class="modal-overlay" id="modal-overlay"></div>


.modal {
  /* все что мы уже выше описали */
 z-index: 1010;
}

.modal-overlay {
  z-index: 1000;
  position: fixed;
  top:0;
  left:0;
  width: 100%;
  height: 100%;
}

Закрывать классом, а не открывать классом

Я заметил распространенное явление, когда по умолчанию .modal класс скрыт, как например display: none; Потом, чтобы открыть, добавляют класс .modal.open {display: block;}

Однако, это может быть и плохо, потому что ваша модальное окно может быть display: flex; и display: block; его перепишет.


.modal {
.display: flex;
}

.modal.closed {
display: none;
}

Добавим JavaScript


var modal = document.querySelector("#modal"),
    modalOverlay = document.querySelector("#modal-overlay"),
    closeButton = document.querySelector("#close-button"),
    openButton = document.querySelector("#open-button");

closeButton.addEventListner("click", function(){
   modal.classList.toggle("closed");
   modalOverlay.classList.toggle("closed");
});

openButton.addEventListner("click", function(){
   modal.classList.toggle("closed");
   modalOverlay.classList.toggle("closed");
});

ДЕМО СКАЧАТЬ

Оригинал статьи на CSS Tricks (англ)

 

 

Рубрики
Разработка

О чем был PiterCSS?

В эту пятницу в Санкт-Петербурге состоялось мероприятие PiterCSS. Самые известные фронт-эндщики (и не только) собрались, чтоб послушать спикеров со всего мира. Выступали представители Венгрии, Канады и Китая. Впрочем было кое-что.

Но что там делать помимо слушанья?

Интересные стенды предоставляли фирмы партнеры. Отечественная фирма с мировым именем JetBrains дарила подарки всем, кто предложит нововведение для их софта. Супер крутой обучающий сервис HTML Academy предлагал сверстать макет на время, но без просмотра результата в браузере.

Образование для самых юных

Отдельное внимание, хотелось бы уделить очень интересной школе образование детей до 15 лет Digital Banana. Эти ребята предоставили стенд с играми, которые были написаны детьми 11 – 12 лет. В данный момент идет набор в летние группы, так что спешите.