Грамотное сворачивание содержания в адаптивном шаблоне

Адаптивный дизайн сайтов имеет свои ограничения и подводные камни. Распространенной практикой изменения верстки содержания при уменьшении ширина окна просмотра является уродливая формула: 1) все перестраивается в одну колонку; 2) информация из боковой панели сдвигается вниз. Но более практичный и оптимальный вариант требует искусного переплетения информационных потоков различных типов содержания по примеру сложенных пальцев рук, как на рисунке.

 

Практический пример

Рассмотрим шаблон для большого размера окна. Две колонки. Статьи располагаются в широкой колонке слева, рекламные баннеры - в узкой колонке справа.

Для экрана с меньшей шириной шаблон будет изменяться в одну колонку. Такой шаблон можно построить с помощью плавающих блоков, что является достаточно распространенной тенденцией в наши дни. К сожалению такой метод требует установления ширины для элементов каждой колонки равной 100% и определения порядка следования (что будет вверху, а что внизу). Обычно, вся реклама сдвигается вниз. Очевидно, что такое решение ущербно. Гораздо лучше было бы вставлять рекламу между блоками содержания.

 

Но как?

Есть несколько методов для решения поставленной задачи. С помощью JavaScript можно измерять ширину экрана и перетасовывать элементы в структуре DOM. Достаточно сложный путь, но его основным преимуществом будет отличная поддержка в разных браузерах. Но мы рассмотрим решение на основе CSS. Будем использовать регионы CSS.

<section class="main-content">

  <article> ... </article>

  <div class="ad-region-1">
    <!-- пусто, для добавления рекламного блока сюда -->
  </div>

  <article> ... </article>

  <div class="ad-region-2">
    <!-- пусто, для добавления рекламного блока сюда
 -->
  </div>

  <article> ... </article>

  <div class="ad-region-3">
    <!-- пусто, для добавления рекламного блока сюда
 -->
  </div>

</section>

<aside>
   <!-- Для обратной совместимости, клон #ad-source -->
</aside>

<!-- Источник содержания для рекламных блоков, обычно скрытые элементы -->
<div id="ad-source">
  <a href="#"><img src="/ads/1.jpg"></a>
  <a href="#"><img src="/ads/2.jpg"></a>
  <a href="#"><img src="/ads/3.jpg"></a>
  <a href="#"><img src="/ads/4.png"></a>
</div>

Обратите внимание на сгруппированные в элементе <div> внизу страницы рекламные блоки. Как только будут установлены регионы CSS, данный элемент будет скрыт и содержание будет перемещаться в указанные регионы.

 

CSS

Содержание блока div #ad-source будет перенаправляться в "именованный поток":

#ad-source {
  -webkit-flow-into: ads;
  -ms-flow-into: ads;
}

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

'ads'  - произвольно выбранное имя, оно может быть любым.

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

aside, [class^='ad-region'] {
  -webkit-flow-from: ads;
  -ms-flow-from: ads;
}

В нашем примере для широкого окна браузера размер элемента aside будет достаточным, чтобы содержать все элементы. Для более узких экранов с помощью медиа запросов элемент aside будет скрываться, вынуждая поток содержания появляться в промежуточных элементах div.

[class^='ad-region'] {
  display: none;
  height: 155px;
  width: 100%; /* Требуется в обязательном порядке */
}

@media (max-width: 800px) {
  [class^='ad-region'] {
    display: block;
  }
  [class^='ad-region']:last-child {
    height: 300px; /* Приходится задавать высоту блока */
  }
  aside {
    display: none;
  }
}

 

Поддержка в браузерах

В настоящий момент регионы CSS поддерживаются в Chrome 16+ и Safari 5.2+.

Данный код HTML и CSS выглядит очень коряво в браузерах, которые не поддерживают регионов CSS. Поэтому добавим немного JavaScript  для проверки и установки соответствующего класса для элемента  html.

// Функция проверки
var supports = (function() {
   var div     = document.createElement('div'),
       vendors = 'Khtml Ms O Moz Webkit'.split(' '),
       len     = vendors.length;  

   return function(prop) {
      if ( prop in div.style ) return true;  

      prop = prop.replace(/^[a-z]/, function(val) {
         return val.toUpperCase();
      });  

      while(len--) {
         if ( vendors[len] + prop in div.style ) {
            return true;
         }
      }
      return false;
   };
})();  

// Проверка 
if ( supports('flowInto') ) {
   $("html").addClass('cssregions');
} else {
   $("html").addClass('no-cssregions');
}

Добавляем код CSS:

#ad-source {
  display: none;
}
.cssregions #ad-source {
  display: block;
  -webkit-flow-into: ads;
  -ms-flow-into: ads;
}

Также надо скопировать содержание блока div #ad-source в элемент aside, чтобы реклама выводилась здесь при больших размерах экрана.

Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/q-ubhjL8Zf0/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

Грамотное сворачивание содержания в адаптивном шаблоне | | 2012-06-19 11:58:57 | | Статьи Web-мастеру | | Адаптивный дизайн сайтов имеет свои ограничения и подводные камни. Распространенной практикой изменения верстки содержания при уменьшении ширина окна просмотра является уродливая формула: 1) все | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: