webew
Войти » Регистрация
 
CSS :: Frameworks

Обзор Reset CSS в фреймворке Yahoo! YUI

10 мая 2008, 19:35

Положительный отзыв о библиотеке 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;}

Разберем более подробно приведенные правила:

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! постоянно обновляют фреймворк, так что вам не придется прилагать много усилий для апгрейда вашего ресета.
Вообщем, пиарю! Знаете еще хорошие css-обнуляторы? Пишите в комментах! А если не знаете — всё равно пишите ;-)

© Все права на данную статью принадлежат порталу webew.ru. Перепечатка в интернет-изданиях разрешается только с указанием автора и прямой ссылки на оригинальную статью. Перепечатка в печатных изданиях допускается только с разрешения редакции.
Добавить комментарий
Отображение комментариев: Древовидное | Плоское
NO USERPIC

rgbeast

Все-таки CSS невалидный, согласно валидатору w3c из-за *font-size:100%;
10.05.2008, 22:29
Ответить

bur

Недоглядел, спасибо!
Всё-таки ИЕ наследил...
11.05.2008, 00:27
Ответить
NO USERPIC

tenshi

мне больше нравится такой: http://d-o-b.ru/style/css/main/_clear.css - он не только обнуляет всё, что только можно, но и исправляет иешные баги с наследованием.
01.06.2008, 23:26
Ответить
NO USERPIC

Octane

sup {vertical-align:text-top;}
sub {vertical-align:text-bottom;}


Такое решение совершенно не исправляет тот факт, что при добавлении sup и sub увеличивается междустрочный интервал, тут должно быть написано что то типа:

sub, sup {
position : relative;
display : inline-block;
font-size : 11px;
line-height : 11px;
}
sub {
top : 5px;
vertical-align : middle;
}
sup {
top : -2px;
margin-top : -11px;
}
20.06.2008, 19:09
Ответить

bur

Не думаю, что Ваш код имеет отношение к ресету. Это скорее типографика, а применение конкретных значений в пикселях точно не претендует на универсальность.
23.06.2008, 12:33
Ответить
Добавить комментарий
Отображение комментариев: Древовидное | Плоское
© 2008—2024 webew.ru, связаться: x собака webew.ru
Сайт использует Flede и соответствует стандартам WAI-WCAG 1.0 на уровне A.
Rambler's Top100

Реклама: