Структура DOM в случае ошибок в разметке HTML

Ошибки при построении разметки могут приводить к разному результату в разных браузерах. Конечно, исходный код будет везде одинаков, но если проверить структуру DOM с помощью инструментов разработчика, то результат будет различаться.

Вот какой код будем проверять:

<div>
	<p><span><b>Некий текст</span></b></p>
</div>

Указанный код вставлен в правильную структуру тега <body>.

Внутри элемента параграфа имеется ошибка закрытия тегов: открывается тег <span>, затем открывается тег <b>, но тег <span> закрывается первым.

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

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

Chrome 9

Firefox 3.6

Internet Explorer 9

Opera 11

Safari 5

Построенная структура DOM имеет различия.

 

Казалось бы, что такого? Но неправильная структура DOM может влиять на CSS и JavaScript, которые используют указание элементов в коде. Можно подумать, что такая ситуация никогда не случится, потому что код всегда проходит проверку. Но если страница генерируется динамически или на ней имеется пользовательское содержание, то вероятность появления подобной ошибки весьма высока. Конечно, проблема не имеет глобального значения, но относится к разряду "никто не знает, что может случиться".

Другой фактор, о котором следует упомянуть - одинаковое выполнение кода веб языков. Спецификация  HTML5 включает инструкции для браузеров, как обрабатывать ошибки в разметке. Если им следовать, то код с ошибками будет одинаково отображаться в разных браузерах. Однако сейчас имеется ситуация, которая может предоставить сюрприз для разработчика при проверке кросс-браузерности его творения.

Firefox 3.6, IE9, и Safari 5 выводят дополнительный элемент. Достаточно свежие версии браузеров показывают различный результат (особенно странной является ситуация с Safari и Chrome, которые построены на одном движке WebKit). Если разработчики браузеров руководствовались спецификацией в случае обработки ошибок в разметке, почему мы имеем разный результат?


Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/QqiZ3CmPThU/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

Структура DOM в случае ошибок в разметке HTML | | 2012-06-19 12:03:28 | | Статьи Web-мастеру | | Ошибки при построении разметки могут приводить к разному результату в разных браузерах. Конечно, исходный код будет везде одинаков, но если проверить структуру DOM с помощью инструментов разработчика | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: