Pull to refresh

Краткий обзор Reset CSS в фреймворке Yahoo! YUI

Reading time3 min
Views1.3K
Хотя на Хабре уже достаточно хорошего материала по css-фреймворкам, и Yahoo! YUI в частности, хотелось бы отдельно остановиться на Reset 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 © 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
Tags:
Hubs:
+10
Comments26

Articles