Соответствие росту детей в пределах каждого родителя

Я пытаюсь собрать часть JQuery, которая найдет дочерние элементы родителя и сделает их такими же высотой, как самый высокий ребенок в родительском элементе.

Это идет не так, потому что высота соответствует всем дочерним элементам и должна применяться к каждому родительскому элементу уникально.

Глянь сюда

Как вы можете видеть выше, высота столбцов полной ширины соответствует высоте 50% нижнего правого столбца. Этого не должно происходить, столбец полной ширины должен иметь собственную высоту.

var colHeight = 0;
$('div.column-holder').children().each(function() {
  if ($(this).height() > colHeight) {
    colHeight = $(this).height();
  }
});
$("div.column").height(colHeight);
<script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class = "column-holder">
  <div class = "column">
    <div class = "shadow bg-white">
      <div class = "bdr-top-blue"></div>
      <div class = "container">
        <h2>Test</h2>
        <p>Lorem ipsum</p>
      </div>
    </div>
  </div>
</div>
<div class = "column-holder">
  <div class = "column">
    <div class = "shadow bg-white">
      <div class = "bdr-top-blue"></div>
      <div class = "container">
        <h2>Test</h2>
        <p>Lorem ipsum</p>
      </div>
    </div>
  </div>
  <div class = "column">
    <div class = "shadow bg-white">
      <div class = "bdr-top-blue"></div>
      <div class = "container">
        <h2>Test</h2>
        <p>Lorem ipsum</p>
        <p>Lorem ipsum</p>
        <p>Lorem ipsum</p>
      </div>
    </div>
  </div>
</div>

Виноват. Я отредактировал сообщение и добавил в переменную для colHeight

user10190915 10.08.2018 11:44
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
1
52
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

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

$('div.column-holder').each(function() {
  var parent = $(this);
  var maxHeight = 0;
  parent.children().each(function() {
     if ($(this).height() > maxHeight) {
         maxHeight = $(this).height();
     }
  });
  parent.find("div.column").height(maxHeight);
 });

Отличное предложение и рабочее решение. Спасибо за помощь!

user10190915 10.08.2018 12:30

Другие вопросы по теме