Многослайдовый баннер на гаджете Лента изображений без JavaScript (только CSS)С начала разработки каскадных таблиц стилей третьей версии, возможности верстальщика растут экспоненциально. Всё больше функционала можно реализовать на «чистом» CSS. В данной работе предлагается разработка интерактивного слайдера без единой строчки какой бы то ни было реализации ECMAScript (например, JavaScript или JScript – сокращённо JS). Автоматическая ротация, интерактивный выбор любого слайда с плавным переходом – всё это реализовано на «чистом» CSS. ВведениеСвойства transition, animation и transform уже давно, в том или ином виде, реализованы во всех популярных браузерах. 6 июня 2012 года консорциум W3C объявил, что эта часть разрабатываемого стандарта CSS 3.0 кардинально меняться не будет, и рекомендовал реализовать её всем браузерам уже сегодня. Для разработчиков всех популярных браузеров это означает, что пришла пора удалить префиксы к именам указанных свойств, поскольку сами свойства уже реализованы, причём очень близко к стандарту. Для фронт-энд разработчиков это означает появление стандарта, на который можно опираться. Теперь не надо бояться, что в будущем какой-либо браузер откажется от своего префиксного нестандартного свойства – ведь оно будет продублировано стандартным свойством и заменит его при необходимости. Устаревшие версии Internet Explorer, к которым скоро можно будет отнести даже 9 версию, не поддерживают transition, animation и transform ни в каком виде. Но их доля всё ещё значительна и превышает 10%.В данной работе для основного функционала для IE7-9 предлагается js-«заглушка», а для дополнительного функционала – эффекта плавного переключения между слайдами, согласно принципу graceful degradation – ничего. CSS против JS
БЭМИтак, для именования CSS классов использовалась методология Блок Элемент Модификатор (БЭМ https://github.com/bem). Суть в том, что вёрстка основана на компоновке страницы из независимых блоков. Согласно БЭМ у блока могут быть элементы, но только внутри блока. Вот CSS классы данной работы:
Особенности использования анимацииВ сети интернет есть много информации об использовании CSS анимации, поэтому мы ограничимся описанием особенностей конкретной реализации.
Главная особенность реализации слайдера в том, что всем слайдам и всем кнопкам присваивается одна и та же анимация:
Такой подход позволяет серьезно сократить объем кода, ведь все анимации пока ещё приходится дублировать их префиксными версиями (@-webkit-keyframes, @-moz-keyframes и @-o-keyframes), а каждую такую «стопку» правил надо отдельно описывать для каждого требуемого (заказчиком) числа слайдов. Если отдельно описывать анимацию ещё и для каждого слайда, то объем кода может составить десятки килобайт. Чтобы этого избежать, но последовательно анимировать все слайды и кнопки при помощи одной анимации, достаточно расставить смещение начала анимации во времени для каждой пары слайд + кнопка:
Для первой пары остаётся значение по-умолчанию – нулевое смещение. Также важно, что смещение не зависит от количества слайдов, и может быть описано один раз для их максимального количества. В итоге плавный анимированный переход между слайдами выглядит следующим образом: Пауза при наведении курсораЕсть целый ряд CSS «событий», переключающих состояние html элемента. Если говорить о клике мыши, то это появление псевдоклассов :focus, :target, или :checked у одного из элементов страницы. Псевдокласс :focus может быть не более чем у одного элемента на страницу единовременно; псевдокласс :target засоряет «хистори» браузера и требует наличие тега «a»; псевдокласс :checked запоминает состояние до ухода со страницы, плюс, в случае радиокнопок, является дискретным переключателем, когда выбран может быть только один элемент конкретной группы – а это то, что нужно.
В селекторах CSS уровня ниже 4.0 переключить состояние произвольного элемента (например, opacity слайда) можно только в связке с радиокнопкой, при помощи селекторов соседей + и ~. Переключить можно как стили соседа, так и стили потомков соседа, но в любом случае сосед должен находиться после радиокнопки.
Было использовано переключение opacity слайда – контейнера, который содержит картинку. Это более универсальный способ, чем переключение свойств картинки, поскольку в div-контейнер, в отличие от пустого элемента img, можно поместить любую дополнительную информацию (например, название слайда, или связанное описание, включая ссылки). Для слайдов указаны свойства transition, которые позволяют сделать переключение между ними плавным.
Остановка ротации при выборе слайдаПри выборе пользователем любого слайда необходимо остановить анимацию всех слайдов и кнопок. Это связано с тем, что приоритет значений свойств запущенной анимации всегда выше всех остальных значений тех же свойств (можно перебивать даже inline свойства с !important`ом). Поскольку анимация, пусть и одинаковая по структуре, есть у каждого слайда, а выключать надо анимацию всех слайдов (иначе в плавном переходе будут участвовать три слайда), все радиокнопки надо располагать до первого слайда.
Более того, все кнопки (лейблы радиокнопок) надо группировать в отдельном блоке и помещать после радиокнопок, иначе могут возникнуть проблемы с универсальным позиционированием лейблов для произвольного числа слайдов. Остановка анимации всех слайдов и кнопок при выборе любого слайда задаётся следующим образом:
Произвольное число слайдовСделать универсальный слайдер под любое число слайдов невозможно, потому что под каждое число требуется своя «стопка» CSS-правил анимации. Каждую такую «стопку» (если она описана) можно подключать через модификатор блока image-tape:
Для поддержки некоторых старых браузеров первый слайд не анимируется. По этой причине контейнер первой картинки имеет opacity всегда равный 1.0. Возникает проблема: при плавном переключении двух других слайдов между собой, первый просвечивает (это может быть и background родителя блока image-tape). Для удаления эффекта просвечивания устанавливается задержка transition-delay для всех слайдов, кроме выбранного; для выбранного же устанавливается z-index больше, чем у всех остальных:
Чтобы слайды не конфликтовали с другими элементами сайта (например, не перекрывали выпадающее меню с z-index менее или равным 6), создаём свой контекст (stacking context) для блока путём задания минимально, необходимого для видимости, z-index`а:
Теперь все элементы блока будут "конфликтовать" только между собой. Реализация на Amiro.CMSВесь CSS необходимо добавить во вкладку Пользовательские стили CSS при редактировании любого макета. После сброса кэша браузера этот код будет присутствовать на всех страницах сайта. Впрочем, частично, или даже полностью, CSS можно вставить непосредственно в шаблон imagetape.tpl в тег style. Это уменьшает объём подключаемого на каждую страницу сайта CSS файла, работает во всех браузерах, валидно в html5 при наличии атрибута scoped, а в условиях вёрстки независимыми блоками не влияет на другие части страницы. При попытке вывода требуемого html кода посредством шаблона imagetape.tpl возникает две проблемы: 1. 1. В сете image, в котором заключен html код одного слайда, отсутствует счетчик (переменная, принимающая значения от 1 до количества слайдов N), который необходим для связки между собой радиокнопок и лейблов. 2. 2. Требуется группировка радиокнопок до всех слайдов, и лейблов после всех слайдов, но их количество должно однозначно соответствовать количеству слайдов. В сетах многократного использования счетчик можно организовать следующим образом:
Здесь символ @ означает, что справа от него находится php выражение (не рекомендуется его использовать слишком часто). Весь php код, в отличие от условных конструкций if-else-endif, выполняется ещё на этапе набора html кода из сетов , поэтому счетчик будет работать. Для группировки списка лейблов и радиокнопок используется такой код:
В итоге, у нас получается html код, в котором сначала идёт список радиокнопок, затем список слайдов с баннерами, а затем блок с списокм лейблов:
ВыводУже сегодня, без навыков программирования и специализированных библиотек, до своей окончательной стандартизации, CSS 3.0 позволяет реализовывать сложный и интересный функционал. Предложенный интерактивный слайдер, на текущий момент, полностью работоспособно у 80% пользователей рунета. Для большей части оставшихся пользователей, а именно для пользователей браузеров IE7-9, можно использовать js-«заглушку», которая реализует основной функционал слайдера. Шаблон с предложенным решением включен в шаблоны версии 5.14.6
Комментарии (7)
Ваш комментарий
|