search check home clock-o tag tags chevron-left chevron-right chevron-up chevron-down twitter facebook github rss comment comments terminal code

[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

  • jAcko

    świetny skrypt! tak banalnie prosty, a tak ułatwiający życie.
    pozdrawiam!

  • jAcko

    mam jednak pytanie… skrypt w firefoxie jakby nie zawsze chwyta za pierwszym razem.
    przykłady:
    a) galeria thickbox – kolumna z miniaturkami (krótsza bez ładowania zdjęć) się nie wydłuża,
    b) czasem pierwotnie krótsza kolumna jest w połowie przedzielona przez border-bottom.
    czy da się jakoś ten efekt usunąć?

    może da się jakoś ustalić kolejność ładowania poszczególnych divów?

  • wiesz, mnie to zastanawia, ponieważ w tym przypadku to zawsze działa. Piszesz że korzystasz z galerii thickbox, może coś źle napisałeś w kodzie strony?
    cięzko tak bez jakiegokolwiek podglądu cokolwiek zdziałać czy zasugerować.

  • jAcko

    mowa tu o stronie:
    http://studioruchu77.pl/nowa/

    żywcem skopiowałem Twój skrypt i… zresztą sam zobacz. poza tym walidację strona przechodzi. może to dlatego, że kolumny ‚lewa’ i ‚prawa’ umieściłem w tzw. ‚kontenerze’? raczej nie, ale… hmmm… sam nie wiem.

    pozdrawiam

  • przydało się 🙂 wielkie dzięki !!

  • jak wyżej napisałem, przydało się i jest ok ale pod IE 7 świruje strasznie… prosze o poradę link do strony zamieszczam pod nickiem.

  • SuchyMTW

    Świetny, a zarazem prosty skrypcik. Wielkie dzięki, pewnie jeszcze nie raz mi się to przyda 🙂

  • olo

    witam, tworzę swoją pierwszą stronkę i też mam podobny problem, co Jacko. Tzn. w firefoxie śmiga, w IE i pod Operą również, ale w Google Chrome za pierwszym razem „ucina” mi środkową kolumnę, dopiero po wejściu drugi raz na tą samą podstronę jest ok, jakby ktoś wiedział, jak rozwiązać ten problem to będę wdzięczny za informacje pozdrawiam 🙂