Категории
Самые читаемые
PochitayKnigi » Компьютеры и Интернет » Интернет » HTML5 для веб-дизайнеров - Кит Джереми

HTML5 для веб-дизайнеров - Кит Джереми

Читать онлайн HTML5 для веб-дизайнеров - Кит Джереми

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 6 7 8 9 10 11 12 13 14 15
Перейти на страницу:

Добавленное в HTML5 содержимое-разделитель позволяет вам явно размечать начало и конец взаимосвязанного содержимого:

<h1>An Event Apart</h1>

<section>

<header>

<h2>Города</h2>

</header>

<p>Присоединяйтесь к нам в 2010 году в этих городах.</p>

<h3>Сиэтл</h3>

<p>Идите в изумрудныйгород по дороге из желтого кирпича.</p>

<h3>Бостон</h3>

<p>Для друзей – Beantown.</p>

<h3>Миннеаполис</h3>

<p>Здесь так <em>мило</em>.</p>

</section>

<small>Размещение не предоставляется.</small>

Теперь ясно, что элемент small подпадает под заголовок “An Event Apart”, а не «Миннеаполис».

Я могу разделить это содержимое на еще более мелкие части: тогда каждый город окажется в своей собственной секции:

<h1>An Event Apart</h1>

<section>

<header>

<h2>Города</h2>

</header>

<p>Присоединяйтесь к нам в 2010 году в этих городах.</p>

<section>

<header>

<h3>Сиэтл</h3>

</header>

<p>Идите в изумрудныйгород по дороге из желтого кирпича.</p>

</section>

<section>

<header>

<h3>Бостон</h3>

</header>

<p>Для друзей – Beantown.</p>

</section>

<section>

<header>

<h3>Миннеаполис</h3>

</header>

<p>Здесь так <em>мило</em>.</p>

</section>

</section>

<small>Размещение не предоставлятся.</small>

Содержание при этом будет таким же:

• An Event Apart

• Города

• Сиэтл

• Бостон

• Миннеаполис

Алгоритм содержания

Пока новое содержимое-разделитель не дает нам ничего такого, чего мы не могли бы делать с предыдущими версиями HTML. Вот самое интересное: в HTML5 у каждого содержимого-разделителя есть свое собственное внутреннее содержание. Таким образом, вам не нужно следить, на каком уровне заголовков вы находитесь, – можете просто каждый раз начинать с h1:

<h1>An Event Apart</h1>

<section>

<header>

<h1>Города</h1>

</header>

<p>Присоединяйтесь к нам в 2010 году в этих городах.</p>

<section>

<header>

<h1>Сиэтл</h1>

</header>

<p>Идите в изумрудныйгород по дороге из желтого кирпича.</p>

</section>

<section>

<header>

<h1>Бостон</h1>

</header>

<p>Для друзей – Beantown.</p>

</section>

<section>

<header>

<h1>Миннеаполис</h1>

</header>

<p>Здесь так <em>мило</em>.</p>

</section>

</section>

<small>Размещение не предоставляется.</small>

В предыдущих версиях HTML содержание было бы построено неправильно:

• An Event Apart

• Города

• Сиэтл

• Бостон

• Миннеаполис

В HTML5 содержание строится правильно:

• An Event Apart

• Города

• Сиэтл

• Бостон

• Миннеаполис

hgroup

Бывают времена, когда вы хотите использовать элемент заголовка, но не хотите, чтобы его содержимое появлялось в содержании документа. Именно это позволяет вам сделать элемент hgroup:

<hgroup>

<h1>An Event Apart</h1>

<h2>Для людей, которые создают вебсайты</h2>

</hgroup>

В этом случае заголовок второго уровня («Для людей, которые создают веб-сайты») – это на самом деле слоган. В элементе hgroup только первый заголовок войдет в содержание. Первый заголовок не обязательно должен быть h1:

<hgroup>

<h3>Скрипты для DOM</h3>

<h4>Веб-разработка на JavaScriptдля Document Object Model</h4>

</hgroup>

Корневые элементы разделов

Некоторые элементы не появляются в сгенерированном содержании. Другими словами, неважно, сколько заголовков вы используете внутри своих элементов, – в содержании документа они не появятся.

Элементы blockquote, fieldset и td являются исключениями для алгоритма составления содержания. Эти элементы называются «корневыми элементами разделов» – это не нужно путать с элементами-разделителями.

Переносимость

Так как каждый элемент, относящийся к типу контента-разделителя, создает собственное содержание, теперь в вашем документе может быть гораздо больше заголовков, чем просто от h1 от h6. Теперь нет никакого ограничения на то, как глубоко могут спускаться уровни ваших заголовков. Что более важно, теперь вы можете начать представлять свое содержимое в более модульном ключе.

Предположим, у меня есть запись в блоге под названием «Бутерброд с сыром». До HTML5 мне нужно было бы знать контекст, в котором расположена запись, чтобы определить, какой уровень заголовков использовать для заголовка записи. Если запись находится на главной странице, то она появляется вслед за элементом h1, который содержит название моего блога:

<h1>Мой клёвый блог</h1>

<h2><a href="cheese.html">Бутерброд с сыром</a></h2>

<p>Моя кошка съела бутерброд с сыром.</p>

Но если я публикую запись в блоге на отдельной странице, то я хочу, чтобы заголовок записи был заголовком первого уровня:

<h1>Бутерброд с сыром</h1>

<p>Моя кошка съела бутерброд с сыром.</p>

С HTML5 мне не нужно волноваться о том, какой уровень заголовков использовать. Мне нужно просто использовать содержимое-разделитель: в данном случае – элемент article:

<article>

<h1>Бутерброд с сыром</h1>

<p>Моя кошка съела бутерброд с сыром.</p>

</article>

Теперь это содержимое по-настоящему переносимо. Неважно, где оно появляется, на отдельной странице или на главной странице блога:

<h1>Мой клёвый блог</h1>

<article>

<h1>Бутерброд с сыром</h1>

<p>Моя кошка съела бутерброд с сыром.</p>

</article>

Новый алгоритм составления HTML5 выдает правильный результат:

• Мой клёвый блог

• Бутерброд с сыром

Локальные стили

То, что у каждого элемента-разделителя есть свое собственное содержание, делает эти элементы прекрасно подходящими для решений на Ajax. И снова HTML5 показывает свое происхождение из спецификации для веб-приложений.

Однако если вы попытаетесь перенести кусочек содержимого из одного документа в другой, то столкнетесь с рядом проблем. CSS-правила, примененные к главному документу, будут применены и к вставленному содержимому. Это в настоящий момент одна из главных проблем с распространением виджетов в вебе.

HTML5 предлагает решение этой проблемы в виде атрибута scoped, который можно применить к элементу style. Все стили, объявленные внутри этого элемента style, будут применены только к ближайшему родительскому элементу-разделителю:

<h1>Мой клёвый блог</h1>

<article>

<style scoped>

h1 { font-size: 75% }

</style>

<h1>Бутерброд с сыром</h1>

<p>Моя кошка съела бутерброд с сыром.</p>

</article>

В этом примере только у второго элемента h1 будет значение размера шрифта, равное 75%. По крайней мере теория такова. Ни один браузер еще не поддерживает атрибут scoped.

В этом-то и загвоздка. Перед тем как начать использовать какое-либо новое добавление в HTML5, вам нужно учесть, какие браузеры поддерживают эту функцию. Впрочем, какой бы ни была браузерная поддержка, у меня есть несколько стратегий, которые помогут вам начать работать с HTML5. В следующей, последней главе я хотел бы поделиться с вами этими стратегиями.

6. Использование HTML5 сейчас

Если вы хотите начать использовать новые структурные элементы HTML5 прямо сейчас, вам ничто не мешает. Большинство браузеров позволят вам назначать стили новым элементам. Дело не в том, что браузеры активно поддерживают эти элементы, а в том, что большинство браузеров позволяют использовать и назначать стили любому элементу, который вы захотите изобрести.

Стили

Браузеры по умолчанию не применяют к новым элементам никаких CSS-стилей. Так что по крайней мере вы, скорее всего, захотите объявить, что все новые структурные элементы должны начинаться с новой строки:

section, article, header, footer, nav, aside, hgroup {

display: block;

}

1 ... 6 7 8 9 10 11 12 13 14 15
Перейти на страницу:
Тут вы можете бесплатно читать книгу HTML5 для веб-дизайнеров - Кит Джереми.
Комментарии