@frilix
Иногда "творю"

Определение размера элемента Qjuery?

Доброго времени суток! Не могу определить минимальный размер из набора изображений.
7d19a84c3a9e4ea489ec623de7f213f1.png
Для того, чтобы поддерживать эту "сетку" используется много css responsive. Я хочу сделать следующее: определить высоту наименьшего изображения в контексте его блога (то есть не реальную высоту) блока, после чего сделать все блоки изображения этой высотой.

Вот немного наговнокодил:
var $images = $('.portfolio-image img');
  var $min_height = 10000;

  $images.each(function(){

    $(this).load(function(){
      if( $(this).height() < $min_height ){
        $min_height = $(this).height();
      }
    });
  });

  $('.portfolio .grid-items__item').css('height', toString($min_height));
  console.log($min_height);  // Выводит 10000


CSS блока и изображения:
// блок, и еще использую col-md-4
.portfolio .grid-items__item {
    position: relative;
    overflow: hidden;
    height: 230px;
}
.no-padding {
    padding: 0 !important;
}
// Изображение
.img-responsive, .thumbnail>img, .thumbnail a>img {
    display: block;
    max-width: 100%;
    height: auto;

Почему выводит 10000? Если использовать в load лог и вывести высоту, то получаю что надо, но почему-то она не сохраняется в переменную
  • Вопрос задан
  • 95 просмотров
Решения вопроса 1
alexey-m-ukolov
@alexey-m-ukolov Куратор тега JavaScript
Почему выводит 10000?

Потому что console.log (и установка значения, соответственно) выполняется до того, как загрузятся все изображения и выполнится колбэк. Вам нужно использовать промисы, для реализации этого функционала и дожидаться, когда будут загружены все изображения.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

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

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