«Резиновая» ширина колонок + эмуляция высоты

Крайне редко мне доводится верстать полностью резиновые макеты, т.е. когда требуется «резиновая» ширина не только для самой страницы, но и для всех колонок (как правило, боковые колонки на моей практике бывают фиксированной ширины).

И вот недавно такой случай попался. И это меня немножко поднапрягло =) Пытался искать в Интернете решение похожей задачи, но совсем ничего не нашел.

Задача

  • Полная «резина»: и ширины страницы, и ширины 2-х колонок (контент + сайдбар).
  • Необходимость эмулировать одинаковую высоту колонок. У сайдбара фон в виде серого цвета. Нужно было сделать так, чтобы серый фон всегда тянулся до футера, независимо от количества содержимого в той или другой колонке.

В моем случае было исключено применение метода padding-bottom: 32767px; margin-bottom: -32767px по той простой причине, что я верстал под WordPress, а там используются ссылки-якори, и, в результате применения данной методики, при переходе по таким ссылкам в ряде браузеров с экрана прячется все, что находится до якоря.

Решение

Единственное, что я смог придумать — создать дополнительный пустой блок, который позиционировать абсолютно, придать ему 100% высоты и поместить под сайдбаром, задав соответствующий фон.

Разметка выглядит следующим образом:

<div id="wrapper">
	<div id="column"></div>
	<div id="header"></div>
	<div id="middle">
		<div id="content"></div>
		<div id="sidebar"></div>
	</div><!-- #middle-->
</div><!-- #wrapper -->
<div id="footer"></div>

Для дополнительного блока #column я написал следующие стили:

#column {
	position: absolute;
	top: 0;
	right: 0;
	width: 39%;
	height: 100%;
	background: #E9E9E9;
}

В результате получилось то, что мне было нужно, за исключением одного момента. IE6 не умеет растягивать блок на 100% высоты родительского блока, если задано свойство position: absolute. Т.е., как обычно, потребовался костыль. И он был вставлен следующим образом:

body {height: 100%}
* html #column {height: 999%}

Я указал высоту блоку #column не 100%, а значительно больше предполагаемой высоты всей страницы. А для того, чтобы в IE6 этот блок растягивался в принципе, потребовалось указать 100% высоту тегу body.

Пример

Результат, того, что у меня вышло.

В итоге остался единственный недочет — в IE6 мне не удалось «спрятать» ту часть блока #column, которая уходит под футер. Единственное решение, которая я вижу в такой ситуации — прижать «подвал» к нижнему краю окна браузера, однако это не всегда бывает необходимо.

P.S. Буду рад услышать от вас более элегантные варианты решения выше описанной задачи, если таковые имеются.

Обновление от 15.02.09

Благодаря помощи Сергея (за что выражаю ему благодарность), удалось довести макет до кроссбраузерного состояния. В вышеуказанном примере потребовалось сделать всего 3 изменения:

  1. Высоту блока в IE6 #column необходимо указать НЕ в процентах:
    * html #column {height: 9999em}
    
  2. Сам блок #column нужно перенести в конец контейнера #middle.
  3. Сайдбару #sidebar указать параметр z-index, чтобы он был выше слоя #column.

Кроссбраузерный пример.

Тему можно считать закрытой. Все свободны =)

Комментарии (41)

  1. 13 февраля 2009 г. в 19:53

    В закладки, как раз эмуляцию высоты не знал как делать.

  2. Санитар
    13 февраля 2009 г. в 21:17

    То, что легко и триаивально делается таблицами, ага…

  3. 13 февраля 2009 г. в 21:52

    Привет! А мой пример можешь «добить», чтобы получилось, как у тебя? У меня что-то не получается. Хочется увидеть, какие конкретно правила нужно добавить/изменить.

    1. gordi
      13 февраля 2009 г. в 21:57 / ответ на коммент Dimox

      Попробую.
      Должно получиться :)

  4. Валентин
    14 февраля 2009 г. в 14:24

    а вот как бы сделать подобную верстку ток трехколоночную со средней резиновой

  5. 14 февраля 2009 г. в 19:36

    Спасибо Вам за статью!

    >Буду рад услышать от вас более элегантные варианты решения выше описанной задачи, если таковые имеются.
    Написал отзыв на вашу статью у себя в блоге, буду рад обратной ссылке.

    На счет элегантности зарекаться не буду, но абсолютного позиционирования и строчек вида height: 999% мне удалось избежать.
    Пример — http://installero.ru/examples/liquid-columns/

    Единственное, чего я так и не смог понять — это кривого поведения при открытии дополнительного текста в сайд-баре в ie6. Но это к верстке отношения (вроде бы) не имеет, если сделать статический код, все работает отлично. Подскажите, если не сложно.

    1. gordi
      14 февраля 2009 г. в 21:45 / ответ на коммент Installero

      но абсолютного позиционирования и строчек вида…

      А теперь попробуем сделать min/max-width и эмуляцию оного для IE6 блоку .wrapper, задать background-color или background:url(…) для body
      Оптимизма думаю по убавиться :)
      Одинаковой высоты колонок, как не бывало :)

      Единственное, чего я так и не смог понять…

      А над этим давно бьются :)
      И за два часа вам не удалось решить проблему :)
      Высказывания на вашей тест-странице сильно позабавили, особенно:

      На самом деле, для того, чтобы научиться адекватно верстать страницы в html+css, необходимо всего несколько дней…

      Если бы все было так просто :)
      Без обид.

      1. 14 февраля 2009 г. в 22:01 / ответ на коммент gordi

        А теперь попробуем сделать min/max-width блоку .wrapper

        А зачем? Если надо-таки ограничить все это по ширине, заверните в ещё один div и задайте ему max-width.

        И за два часа вам не удалось решить проблему!

        Вам виднее, конечно ;)

        1. gordi
          14 февраля 2009 г. в 22:30 / ответ на коммент Installero

          …заверните в ещё один div…

          Введение дополнительного контейнера потянет за собой проблему равной высоты колонок при попытке сделать 100% высоту макета, не говоря о том, что проблема с IE6 в вашем примере остается и в контексте поста автора блога, в данном конкретном случае, решения похоже, не имеет.

          1. 14 февраля 2009 г. в 22:51 / ответ на коммент gordi

            Введение дополнительного контейнера потянет за собой проблему равной высоты колонок при попытке сделать 100% высоту макета

            Вы хотите сказать, что не получится одновременно и ограничить макет по ширине и прижать футер к полу, растянув фон?

            1. gordi
              14 февраля 2009 г. в 23:04 / ответ на коммент Installero

              Вы хотите сказать

              А вы попробуйте :)
              Про IE6 не забудьте :)

              У себя на блоге этому много статей посвятил, как раз решая эту проблему, посмотрите, почитайте.
              Повторюсь не все так просто, проблема имеет место быть и ваш пример яркое тому подтверждение.

  6. 15 февраля 2009 г. в 00:06

    А вы попробуйте :)

    Для FF3, IE7, Opera — получилось. Для IE6 — не вышло. Все-таки игрушки крепко к полу прибиты :)
    Но в совокупности с автором поста у нас полный набор. Я привел пример без прижатия футера к земле. Автор — с прижатием. Оба примера (вроде бы) отлично ограничиваются по ширине и высоте.

    1. gordi
      15 февраля 2009 г. в 00:27 / ответ на коммент Installero

      Линка на пример не хватает :)
      Мои примеры работают везде без проблем и нужен-то всего один лишний блок :)
      Причем, если вы видели скриншот по ссылке на статью, что давал в комментарии № 2, то сделать каждой колонке свой border и фон легко и просто, со 100% высотой и footer-ом который всегда внизу :) при минимуме html.

      1. 15 февраля 2009 г. в 00:31 / ответ на коммент gordi

        Ну, мне почему-то кажется, что вы это не 2 часа делали.

        1. gordi
          15 февраля 2009 г. в 00:51 / ответ на коммент Installero

          Ну, мне…

          Около того :)
          Пять вариантов с различным раположением колонок навигации относительно области контента.
          Линки на примеры в комментариях вариация на тему :)

  7. site-creator
    15 февраля 2009 г. в 14:35

    В итоге остался единственный недочет — в IE6 мне не удалось “спрятать” ту часть блока #column, которая уходит под футер

    а вот так не пробовали ?
    #middle { zoom:1; position:relative; overflow:hidden; z-index:2; }
    #sidebar { position:relative; z-index:2; }

    и блок #column поместить в middle

  8. 15 февраля 2009 г. в 14:45

    Большое спасибо! Теперь все получилось.

  9. Riska
    15 февраля 2009 г. в 21:47

    site-creator только что попробовала, но это не поможет, возможно это не то, либо, я что то не так сделал.

    1. site-creator
      15 февраля 2009 г. в 23:03 / ответ на коммент Riska

      в любом случае обрезать высокий блок можно

  10. Юля
    16 февраля 2009 г. в 20:45

    Большое спасибо. Надо обязательно попробовать.

  11. Roman
    17 февраля 2009 г. в 18:19

    Есть еще более интересный вариант, пример:
    http://matthewjamestaylor.com/blog/equal-height-columns-cross-browser-css-no-hacks

    1. 17 февраля 2009 г. в 19:23 / ответ на коммент Roman

      Спасибо за ссылку! Очень интересная техника.

    2. gordi
      18 февраля 2009 г. в 15:32 / ответ на коммент Roman

      Есть еще…

      На мой взгляд вариант не интересен тем, что требует массы дополнительных контейнеров :)
      Причем, в нем не будет возможности сделать каждому блоку отдельную свою рамку (border).
      Но имеет право на жизнь :)

      1. 18 февраля 2009 г. в 16:17 / ответ на коммент gordi

        На счет практичности, конечно же, под вопросом. Но вот сам способ мне понравился, такая заковыристая методика =)

        1. gordi
          18 февраля 2009 г. в 16:29 / ответ на коммент Dimox

          …такая заковыристая…

          В этом то и беда :(
          Если, есть возможность сделать проще, то так и надо делать :)
          Легче будет разобраться не подготовленному человеку.
          В любом случае принцип — «необходимо и достаточно» рулит всегда :)
          Не говоря от том, что надежность разметки повышается в разы :)

          1. 18 февраля 2009 г. в 16:34 / ответ на коммент gordi

            Согласен полностью ;)

      2. Roman
        18 февраля 2009 г. в 16:47 / ответ на коммент gordi

        Причем, в нем не будет возможности сделать каждому блоку отдельную свою рамку (border).

        В данном случае, я думаю, что Вы просто поспешили с ответом.

        1. gordi
          18 февраля 2009 г. в 16:58 / ответ на коммент Roman

          В данном случае…

          Возможно.
          Но посмотрев на нагромаждение лишних блоков, нет никакой охоты разбираться :)
          Возьмите за основу скриншот по моей ссылке на статью из комментрария № 2, в статье есть линки на примеры, если удастся сделать нечто похожее, буду только рад, но учитывая принцип «необходимо и достаточно» и посчитав количество нужных для этого контейнеров к какому выводу вы придете?
          Так стоит ли огород городить?

  12. Dew
    25 февраля 2009 г. в 20:00

    Люди, человеки!
    Я конечно все понимаю, но за конструкцию
    * {
    margin: 0;
    padding: 0;
    }

    руки отбивают

    1. 25 февраля 2009 г. в 20:18 / ответ на коммент Dew

      А в чем проблема?

  13. 11 марта 2009 г. в 13:46

    А как насчет 2-х сайдбаров по бокам фиксированной ширины, а центральную сделать резиновой?

    1. 11 марта 2009 г. в 14:15 / ответ на коммент auditor

      Сходите на http://csstool.ru/, там найдется такой.

  14. namez
    19 марта 2009 г. в 11:16

    Dimox! читаю вас с удовольствием и помощи между делом получить хочу, ткните ссылкой, примером на 3-x колонучную резину где центр фикс а сайдбары в процентах

    с уважением Сергей.

    1. 19 марта 2009 г. в 12:00 / ответ на коммент namez

      Спасибо, Сергей.

      Вот здесь есть несколько вариантов, может быть подойдут — http://www.cssplay.co.uk/layouts/three-column-layouts

  15. ermoha
    16 апреля 2009 г. в 14:11

    Привет. Прочитал статью, комментарии. Но так и не нашел способа с прижатым подвалом к низу экрана. За основу я брал метод с position:absolute.

    1. 16 апреля 2009 г. в 21:48 / ответ на коммент ermoha

      Вам сюда.

  16. ermoha
    16 апреля 2009 г. в 14:29

    У меня с position:absolute тянется блок «column» в зависимости от контента. Больше никак. Так у всех?

  17. Aleksei
    25 октября 2009 г. в 22:00

    Привет Dimox.
    Подскажи как сделать резиновым шаблон. Я хочу сделать на wordpress блог картинок. В кратком описании (до кнопки подробнее ) я вставляю картинку маленького разрешения, а в подробном картинку в полном разрешении. Так при обычном шаблоне картинка вылезает из шаблона и смотрится очень тупо. Я хочу чтобы шаблон растягивался под картинку. Почему я хочу это сделать?
    потому что я пробовал так делать на ucoz и гугл это очень хорошо оценил, но на ucoz это делать очень долго( я про заполнение alt и описаний к картинке).
    Заранее спасибо.

  18. kirill
    14 апреля 2010 г. в 14:17

    А вот у меня на фоне сайта стоит картинка http://nlt-povolje.ucoz.org/ она не умещается в некоторые экраны как мне сделать чтобы он регулировался сам

    1. 14 апреля 2010 г. в 19:42 / ответ на коммент kirill

      Где-то на хабре однажды была статья об этом.

      1. kirill
        15 апреля 2010 г. в 19:05 / ответ на коммент Dimox

        а где точнее

Ваш комментарий

Жирный текст

Ссылка

Цитата

Внутристрочный код

CSS-код

HTML-код

JavaScript-код

PHP-код