Добавить в избранное

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

Дата: 2011-10-13

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

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

1


2

Некий текст


3

 

 

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

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

В действительности такая ситуация соответствует ошибке 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). Если разработчики браузеров руководствовались спецификацией в случае обработки ошибок в разметке, почему мы имеем разный результат?

Источник урока: www.impressivewebs.com/dom-improperly-nested/

сайт tiwebmaster.ru

 

Просмотров: 1941

Последние 5 уроков

Как бороться со всем знакомыми багами IE

Несмотря на то что в основном пользуюn CSS3, иногда все же вынуждают бороться и с Internet Explorer при создании проектов, которые необходжимо зделать кросс-браузерными.


Красивый навигационный блок

Небольшая статья по созданию блока меню, который Вы можете использовать на своем сайте.


Работа с cookie с помощью Jquery

Пример работы с куками на jquary + исходники статьи.


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

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


Видео уроки по php,jquery,ajax,css,html,сео