Хотя на Хабре уже достаточно хорошего материала по css-фреймворкам, и Yahoo! YUI в частности, хотелось бы отдельно остановиться на Reset CSS. Положительный отзыв о этой библиотеке Вадима Макеева на РИТ-2008 просто вынудил меня скачать её и посмотреть что же там внутри.
JavaScript-возможности Yahoo! YUI впечатляют. Беглый просмотр примеров показал, что фреймворк может действительно много, однако, в этой статье речь пойдет о CSS.
Наконец мы добрались обзора Reset CSS, и рассмотрим его более подробно. По пути /yui/build/reset/ обнаруживает readme и два ccs-файла:
Код reset.css
/*
Copyright © 2008, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
developer.yahoo.net/yui/license.txt
version: 2.5.1
*/
html{color:#000;background:#FFF;}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,
code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;}
fieldset,img{border:0;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}
li{list-style:none;}
caption,th{text-align:left;}
h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}
q:before,q:after{content:'';}
abbr,acronym {border:0;font-variant:normal;}
/* to preserve line-height and selector appearance */
sup {vertical-align:text-top;}
sub {vertical-align:text-bottom;}
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
/*to enable resizing for IE*/
input,textarea,select{*font-size:100%;}
/*because legend doesn't inherit in IE */
legend{color:#000;}
Разберем более подробно приведенные правила:
html{color:#000;background:#FFF;}
— белый фон и черный цвет текста полезен, т.к. пользователь в настройках браузера может поставить свои значения по-умолчанию, что испортит дизайн страницы.
куча элементов {margin:0;padding:0;}
— сбрасываем отступы.
q:before,q:after{content:'';}
— сбрасываем содержимое псевдо-элементов цитаты.
abbr,acronym {border:0;font-variant:normal;}
— для аббревиатуры и акронима оставляет
пользовательский вариант регистра символов.
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}
— задает обычное начертание и жирность текста в этих элементах.
fieldset,img{border:0;}
— обнуление бордера. Крайне раздражает дефолтный бордер для изображений в ссылках.
caption,th{text-align:left;}
— левое выравнивание для заголовков и заголовочных ячеек таблицы.
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
— для совместимых со стандартами браузеров (не ИЕ :) заставляет наследовать свойства шрифта элементов форм от родителя.
legend{color:#000;}
— легенда не наследует цвет текста в ИЕ, пропишем его явно.
input,textarea,select{*font-size:100%;}
— 100% ширина полей в ИЕ.
Как-то так.
Вообщем, пиарю!
Кросспост Обзор Reset CSS в фреймворке Yahoo! YUI c webew.ru
Первое впечатление
Библиотека просто громадная! Архив объемом 8.85Мб (на сегодняшний день) скачивался с перегруженного соурсфоржа совсем не быстро. Архив распаковался в папку yui, в которой валяется index.html, для удобной навигации по компонентам библиотеки и просмотра примеров. Собственно громадный размер вызван обилием напичканных в примеры картинок + 350 html-файлов документации + несчетное число js-файлов. «Сердце» библиотеки лежит в папке build — распределенные по директориям файлы компонентов.JavaScript-возможности Yahoo! YUI впечатляют. Беглый просмотр примеров показал, что фреймворк может действительно много, однако, в этой статье речь пойдет о CSS.
О CSS
CSS-составляющая Yahoo! YUI включает четыре основных компоненты (а больше, собственно и не нужно):- Reset CSS — сбрасывает дефолтные стили для HTML-элементов, значения которых разнятся от браузера к браузеру.
- Base CSS — устанавливает единые базовые стили для большинства HTML-элементов (списки, ссылки, заголовки и др).
- Fonts CSS — устанавливает кроссбраузерные значения для базового шрифта на странице (размер, межстрочное расстояние, моноширинность для некоторых элементов типа code)
- Grids CSS — набор стилей для блочной верстки макетов, как с фиксированной шириной, так и резиновых.
Reset CSS
Наконец мы добрались обзора Reset CSS, и рассмотрим его более подробно. По пути /yui/build/reset/ обнаруживает readme и два ccs-файла:
- reset.css — девелоперская версия библиотеки с комментариями.
- reset-min.css — версия для подключения непосредственно на проект, прошедшая через обфускатор, потому без комментариев и в одну строку. Для разбора непригодна.
Код reset.css
/*
Copyright © 2008, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
developer.yahoo.net/yui/license.txt
version: 2.5.1
*/
html{color:#000;background:#FFF;}
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,
code,form,fieldset,legend,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
table{border-collapse:collapse;border-spacing:0;}
fieldset,img{border:0;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}
li{list-style:none;}
caption,th{text-align:left;}
h1,h2,h3,h4,h5,h6{font-size:100%;font-weight:normal;}
q:before,q:after{content:'';}
abbr,acronym {border:0;font-variant:normal;}
/* to preserve line-height and selector appearance */
sup {vertical-align:text-top;}
sub {vertical-align:text-bottom;}
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
/*to enable resizing for IE*/
input,textarea,select{*font-size:100%;}
/*because legend doesn't inherit in IE */
legend{color:#000;}
Разберем более подробно приведенные правила:
html{color:#000;background:#FFF;}
— белый фон и черный цвет текста полезен, т.к. пользователь в настройках браузера может поставить свои значения по-умолчанию, что испортит дизайн страницы.
куча элементов {margin:0;padding:0;}
— сбрасываем отступы.
q:before,q:after{content:'';}
— сбрасываем содержимое псевдо-элементов цитаты.
abbr,acronym {border:0;font-variant:normal;}
— для аббревиатуры и акронима оставляет
пользовательский вариант регистра символов.
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;font-weight:normal;}
— задает обычное начертание и жирность текста в этих элементах.
fieldset,img{border:0;}
— обнуление бордера. Крайне раздражает дефолтный бордер для изображений в ссылках.
caption,th{text-align:left;}
— левое выравнивание для заголовков и заголовочных ячеек таблицы.
input,textarea,select{font-family:inherit;font-size:inherit;font-weight:inherit;}
— для совместимых со стандартами браузеров (не ИЕ :) заставляет наследовать свойства шрифта элементов форм от родителя.
legend{color:#000;}
— легенда не наследует цвет текста в ИЕ, пропишем его явно.
input,textarea,select{*font-size:100%;}
— 100% ширина полей в ИЕ.
Как-то так.
Плюсы
Использование Yahoo! YUI Reset CSS будет безусловно полезно для вашего проекта.- Библиотека внимательно отнеслась ко всем стандартным фиксам и вы можете навсегда забыть про написание в начале всех css-файлов нулевого бордера на имга и коллапса на таблицу.
- Не забыты редкоиспользуемые элементы семантической верстки (не закидывайте тапками за эпитет «редкоиспользуемые», но это действительно так), которые браузеры по умолчанию всегда обрабатывают через пень-колоду. Приятно.
- Библиотека избежала многочисленных невалидных фиксов для ИЕ, из-за чего осталась простой и понятной. Но, к сожалению, не всех :(
- Разработчики Yahoo! постоянно обновляют фреймворк, так что вам не придется прилагать много усилий для апгрейда вашего ресета.
Вообщем, пиарю!
Кросспост Обзор Reset CSS в фреймворке Yahoo! YUI c webew.ru