chevron-left chevron-right

[CSS][jQuery] Równa wysokość kolumn na stronie – wersja 2

Dzisiaj zaprezentuję inny sposób na wyrównanie dwóch kolumn na stronie. Ten sposób się przydaje w momencie gdy strona jest dynamicznie generowana, czyli jej wysokość się stale zmienia zależnie od zawartości.

Najpierw budujemy prosty szablon dwukolumnowy:

<div id="lewa" class="kolumna">
        Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
 
        Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
 
        Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
    </div>
    <div id="prawa" class="kolumna">
 
        Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
    </div>

Dodajemy style dla tego szablonu, by efet był widoczny:

.kolumna {
	width: 250px; 
	float: left; 
	padding: 10px; 
	overflow: hidden; 
	margin: 0 10px 0 0; 
} 
#lewa {
	background-color: #666666; 
	border: solid 1px #FF0000; 
}
#prawa {
	background-color: #00CCCC; 
	border: solid 1px #996699;
}

A następnie wstawiamy kod JavaScript, który będzie porównywał która kolumna jest dłuższa i do tej kolumny będzie dopasowywał wysokość drugiej kolumny:

$(document).ready(function(){
	var kolumnaPrawa =  $("div#prawa").height();
	var kolumnaLewa = $("div#lewa").height();
 
	if (kolumnaLewa > kolumnaPrawa)
	{
		$("div#prawa").css({'height' : kolumnaLewa});
	} 
	else
	{
		$("div#lewa").css({'height' : kolumnaPrawa});
	};
});

W ten sposób osiągnęliśmy swój cel czyli mamy wyrównanie kolumn w sposób dynamiczny. Niezależnie od tego która kolumna jest dłuższa.
Możecie sprawdzić demo z tego artykułu