Обзор Reset CSS в фреймворке Yahoo! YUI
Положительный отзыв о библиотеке Yahoo! YUI докладчика по CSS-фреймворкам на РИТ-2008 просто вынудил меня скачать её и посмотреть что же там внутри.
Первое впечатление
Библиотека просто громадная! Архив объемом 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 (c) 2008, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://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;}
Разберем более подробно приведенные правила:
Как-то так.
Плюсы
Использование Yahoo! YUI Reset CSS будет безусловно полезно для вашего проекта.- Библиотека внимательно отнеслась ко всем стандартным фиксам и вы можете навсегда забыть про написание в начале всех css-файлов нулевого бордера на имга и коллапса на таблицу.
- Не забыты редкоиспользуемые элементы семантической верстки (не закидывайте тапками за эпитет "редкоиспользуемые", но это действительно так), которые браузеры по умолчанию всегда обрабатывают через пень-колоду. Приятно.
- Библиотека избежала многочисленных невалидных фиксов для ИЕ, из-за чего осталась простой и понятной. Но, к сожалению, не всех :(
- Разработчики Yahoo! постоянно обновляют фреймворк, так что вам не придется прилагать много усилий для апгрейда вашего ресета.
© Все права на данную статью принадлежат порталу webew.ru. Перепечатка в интернет-изданиях разрешается только с указанием автора и прямой ссылки на оригинальную статью. Перепечатка в печатных изданиях допускается только с разрешения редакции.