Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 22.08.2018, 11:11
Профессор
Отправить личное сообщение для giwuf Посмотреть профиль Найти все сообщения от giwuf
 
Регистрация: 16.05.2017
Сообщений: 167

Как сохранять равные по высоте блоки независимо от раскрытия списка в одном них?
Всем привет.
Имеются 3 адаптивных столбца с текстовой информацией по мероприятию равной высоты в исходном состоянии независимо от количества контента в них.

Этого добился с помощью набора правил:
Код:
display: flex; flex-direction: column; align-items: stretch;
Далее, каждый список может раскрываться по кнопке подробнее и сворачиваться по крестику, при этом должен сохранять исходную высоту других столбцов. Этого пытаюсь добиться с помощью js, но что-то ускользает из моего вида: то контент выпадает из столбцов, то блок почему-то уменьшается по высоте контента, а не по высоте, которую должен принимать и сохранять из скрипта.
Как добиться запланированного отображения, причем чтобы это был универсальный вариант независимо от количества столбцов и рядов?

фидл

UPD списки должны раскрываться и не налазить на контент ниже (по принципу аккордеона). Примерная реализация здесь, только она пока не адаптивная и работаю над этим

var mh = 0;
   $(".task-box").each(function () {
       var h_block = $(this).height();
       if(h_block > mh) {
          mh = h_block;
       }
   });

   $(".collapse").on("show.bs.collapse", function () {
   
  let boxes = $(".task-box").not($(this).parents(".task-box"));
  let parentBox = $(this).parents(".task-box");

  parentBox.attr("aria-expanded", "true").css("height", "auto");
    boxes.each(function () {
    var $this = $(this);
if ( $this.attr("aria-expanded") !== "true") { 
      $this.height(mh);
      }
      });

   });
   $(".collapse").on('hide.bs.collapse', function () {

  let parentBox = $( this ).parents(".task-box");
  parentBox.attr("aria-expanded", "false").height(mh);
  let boxes = $(".task-box").not($(this).parents(".task-box"));
      boxes.each(function () {
      if($(this).height()>mh) {
      	$(this).css("height", "auto");
      }
      else {
        $(this).height(mh);
      }
      });
   });

<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.2/css/bootstrap.min.css" rel="stylesheet">
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css" rel="stylesheet">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.2/js/bootstrap.min.js"></script>

<div id="task">
<div class="row">
          <div class="col-lg-4 col-sm-6 col-12 mb-5">
          	  <div class="task-box class1" aria-expanded="false">
				  <div class="task-box-inner">
					  <h4>Lorem ipsum dolor sit amet</h4>
					  <hr>
					  <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptatem distinctio nesciunt excepturi similique totam natus, facere corrupti quas tempora. Exercitationem dolorum incidunt soluta ipsa voluptates suscipit eum harum quae veniam.</p>
					  <a data-toggle="collapse" href="#collapseevent-1" role="button" aria-expanded="false" aria-controls="collapseevent-1">
					    Подробнее&nbsp;&nbsp;&nbsp;<i class="fa fa-plus" aria-hidden="true"></i>
					  </a>
					  <div class="collapse" id="collapseevent-1">
					  <div class="card card-body">
					    <p><i class="fa fa-users" aria-hidden="true"></i>11 человек</p>
					    <p><i class="fa fa-map-marker" aria-hidden="true"></i><span>Место встречи</span></p>
					    <a class="join" href="#">Присоединиться</a>
					    <a data-toggle="collapse" href="#collapseevent-1" role="button" aria-expanded="true" aria-controls="collapseevent-1"><i class="fa fa-times" aria-hidden="true"></i></a>
					  </div>
					</div>
				  </div>
          	  </div>
          </div>
		  <div class="col-lg-4 col-sm-6 col-12 mb-5">
		  	  <div class="task-box class2" aria-expanded="false">
			  	  <img class="img-fluid" src="img/event-2.jpg" alt="reportage">
				  <div class="task-box-inner">
					  <h4>Repudiandae ipsa quae molestiae quis sint. </h4>
					  <hr>
					  <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. </p>
	  				  <a data-toggle="collapse" href="#collapseevent-2" role="button" aria-expanded="false" aria-controls="collapseevent-2">
					    Подробнее&nbsp;&nbsp;&nbsp;<i class="fa fa-plus" aria-hidden="true"></i>
					  </a>
					  <div class="collapse" id="collapseevent-2">
						  <div class="card card-body">
						    <p><i class="fa fa-users" aria-hidden="true"></i>5 человек</p>
						    <p><i class="fa fa-map-marker" aria-hidden="true"></i><span>Это замечательное местоa</span></p>
						    <p><i class="fa fa-commenting" aria-hidden="true"></i>Выступающий</p>
						    <a class="join" href="#">Присоединиться</a>
						    <a data-toggle="collapse" href="#collapseevent-2" role="button" aria-expanded="true" aria-controls="collapseevent-2"><i class="fa fa-times" aria-hidden="true"></i></a>
						  </div>
					  </div>
		          </div>
		  	  </div>
	      </div>
		  <div class="col-lg-4 col-sm-6 col-12 mb-5">
		  	  <div class="task-box class3" aria-expanded="false">
			  	  <img class="img-fluid" src="img/event-3.jpg" alt="reportage">
				  <div class="task-box-inner">
					  <h4>Modi, nam maxime aspernatur necessitatibus.</h4>
					  <hr>
              <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Modi, nam maxime aspernatur necessitatibus. Voluptate explicabo, numquam rerum? Ipsa explicabo voluptatum voluptas, rem aliquid, esse libero. Optio tempore repellendus accusantium aliquid.Lorem ipsum dolor sit amet, consectetur adipisicing elit.</p>
	  				  <a data-toggle="collapse" href="#collapseevent-3" role="button" aria-expanded="false" aria-controls="collapseevent-3">
					    Подробнее&nbsp;&nbsp;&nbsp;<i class="fa fa-plus" aria-hidden="true"></i>
					  </a>
					  <div class="collapse" id="collapseevent-3">
						  <div class="card card-body">
						    <p><i class="fa fa-users" aria-hidden="true"></i>1 человек</p>
						    <p><i class="fa fa-map-marker" aria-hidden="true"></i><span>Нет данных</span></p>
						    <a class="join" href="#">Присоединиться</a>
						    <a data-toggle="collapse" href="#collapseevent-3" role="button" aria-expanded="true" aria-controls="collapseevent-3"><i class="fa fa-times" aria-hidden="true"></i></a>
						  </div>
					  </div>
		          </div>
		  	  </div>
          </div>
          </div>
          </div>
<div>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Voluptate aliquid, officia labore vel quod cupiditate veritatis temporibus incidunt consectetur molestiae. Cum voluptatibus nesciunt odit alias sint harum in, officia optio.</div>

#task .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display:         flex;
  flex-wrap: wrap;
}
p {
  padding: 15px;
}
	#task .row > [class*='col-'] {
	  display: flex;
	  flex-direction: column;
	  align-items: stretch;
    margin-bottom: 20px;
	}

.task-box {
  position: relative;
  margin: 0 auto;
  color: rgb(95, 112, 135);
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100%;
  border: 1px solid #000;
}
.task-box .task-box-inner>a[aria-expanded="true"] {
	display: none;
}

Последний раз редактировалось giwuf, 22.08.2018 в 12:45. Причина: дополнил уточнение
Ответить с цитированием
  #2 (permalink)  
Старый 22.08.2018, 12:09
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

giwuf,

https://jsfiddle.net/pnfcs4bo/266/
Ответить с цитированием
  #3 (permalink)  
Старый 22.08.2018, 12:42
Профессор
Отправить личное сообщение для giwuf Посмотреть профиль Найти все сообщения от giwuf
 
Регистрация: 16.05.2017
Сообщений: 167

рони,

я стараюсь сделать так, чтобы блок на контект не налазил, а без js это сделать никак не получится. (в описание внесу это уточнение)

Нужно примерно такое решение с плавными эффектами, только оно не адаптивное и думаю как докрутить.
Ответить с цитированием
  #4 (permalink)  
Старый 22.08.2018, 12:46
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,109

giwuf,
не понимаю, что вам нужно.
Ответить с цитированием
  #5 (permalink)  
Старый 22.08.2018, 14:26
Профессор
Отправить личное сообщение для giwuf Посмотреть профиль Найти все сообщения от giwuf
 
Регистрация: 16.05.2017
Сообщений: 167

Сообщение от рони Посмотреть сообщение
giwuf,
не понимаю, что вам нужно.
рони,

Смотрите - в вашем примере https://jsfiddle.net/pnfcs4bo/266/
при раскрытии списка на кнопку подробнее, сам блоки налазят на текст снизу Lorem ipsum тем самым перекрывая его.
В этом же решении http://jsfiddle.net/op54xnqh блоки раскрываются по принципу аккордеона пододвигая блок с текстом Lorem ipsum, но не перекрывая его. Мне нужно сохранить такое же поведение и сделать его адаптивным, т.к. пока блоки занимают 30% места, остаются зазоры между ними и не центрированы. Плюс такое решение является не универсальным, плохо масщтабируется, нужно каждый раз прикидывать точные проценты ширины
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как вы относитесь к наркоманам? Maxmaxmaximus7 Оффтопик 7 05.02.2014 13:29
Управление скроллом "а-ля тач" HonesT Элементы интерфейса 2 27.08.2013 14:25
Sortable, два связанных списка. Как один из них сделать неизменяемым? kvecxjo jQuery 1 30.03.2010 03:15