Document Object Model + JavaScript |
Модель web-страницы в браузере
При открытии веб-страницы,
браузер:
-
получает исходный текст HTML
-
осуществляет его парсинг (синтаксический разбор)
-
строит модель структуры документа
-
на
основе построенной модели отрисовывает страницу на экране.
Представление документа
в исходном тексте
(коде) HTML
можно:
Изменения удобно производить в специализированных HTML-редакторах. |
HTML-редакторы
Web-страницы можно создавать в редакторах двух основных
типов:
Текстовые редакторы:
HomeSite,
HotDog,
FirstPage, и т.д
WYSIWYG-редакторы:
Dreamweaver,
FrontPage,
Expression Web и т.д. .
В редакторах первого типа пользователь непосредственно
пишет HTML-код. Простейший пример текстового HTML редактора
- Notepad (Блокнот).
В редакторах второго типа можно обойтись без знания HTML и
всего того, что находится за внешней стороной Web-страницы.
Вы просто создаете текст или изображение у себя на экране, и
сохраняете его в формате html.
Генерацию HTML-кода
выполняет программа.
WYSIWYG (What You See Is
What You Get, произносится "визивиг", "что видишь, то и
получаешь") - в текстовых процессорах и настольных
издательских системах - режим полного графического
соответствия печатного варианта и изображения редактируемого
документа на экране. |
DOM
html-документа
Структура данных, использующаяся браузером называется
Document Object Model
(DOM,
объектная модель документа).
Можно представить html-документ как набор вложенных коробок.
Например: теги
<body> и </body> включают
в себя другие теги, которые в свою очередь включают теги, или текст.
Для каждой коробки есть объект, с которым мы можем
взаимодействовать и узнавать про него разные данные – какой тег он
представляет, какие коробки и текст содержит.
|
JavaScript
Язык
программирования
JavaScript
представлен в 1995 году как способ добавлять программы на веб-страницы в
браузере.
JavaScript
обеспечил интерактивность
веб-страницам и дал возможность появиться
современным веб-приложениям.
Брендан Айк (Brendan
Eich) — создатель языка программирования JavaScript.
JavaScript
обычно используется как встраиваемый язык сценариев для придания
интерактивности веб-страницам.
ECMAScript - документ
(модель, стандарт), описывающий работу языка
JavaScript.
Douglas Crockford
(о
JavaScript):
Marijn Haverbeke :
-
Когда мне первый раз пришлось писать программу на JavaScript, я
быстро почувствовал отвращение – язык принимал практически всё, что
я писал, при этом интерпретировал это вовсе не так, как я
подразумевал.
-
JavaScript слишком либерален. Задумывалось это как облегчение
программирования для начинающих. В реальности, это затрудняет розыск
проблем в программе, потому что система о них не сообщает.
-
После того, как я по настоящему изучил и поработал с ним, я научился
любить JavaScript.
|
JavaScript
и DOM
Программы
на языке JavaScript могут:
DOM
представляет модель документа формируемого браузером, а программа JavaScript может
изменять её для изменения видимого документа.
DOM организован в виде дерева,
в котором элементы расположены иерархически в соответствии со структурой
документа.
Доступ JavaScript (JS) к объектам
DOM осуществляется через глобальную переменную
document.
Свойство глобальной переменной
documentElement
ссылается на объект, представляющий
тег и предоставляющий свойства head и body, в которых содержатся
объекты для соответствующих элементов.
У объектов элементов есть свойства
(например: parentNode и childNodes),
которы используются для ориентирования на дереве.
Поведение
документа или его отдельных элементов можно менять внедряя в модель
документа программный код JavaScript.
Внешний вид документа можно изменять через стили, либо добавляя стили к
узлам напрямую, либо определяя правила для каких-либо узлов.
У стилей есть
очень много свойств, таких, как color или display.
JavaScript может влиять
на стиль элемента напрямую через его свойство style.
|
Деревья
Структура
(модель) данных
html-документа
может интерпретироваться в качестве
синтаксического дерева:
каждый узел может ссылаться на
другие узлы, у каждого из ответвлений может быть своё ответвление.
Синтаксическое дерево – типичная
модель вложенных структур, где элементы содержат подэлементы, похожие на них самих.
Структура данных
является деревом, если:
-
она разветвляется,
-
не имеет циклов
(узел не может содержать сам себя),
-
имеет единственный ярко выраженный
«корень».
В случае DOM
html-документа в качестве корня выступает
document.documentElement.
Узлы для обычных элементов, представляющих теги HTML,
определяют структуру документа.
У них могут быть дочерние узлы.
Пример
такого узла — document.body.
Некоторые из этих дочерних узлов могут
оказаться листьями – например, текст или комментарии (в HTML комментарии
записываются между символами <!-- и --> ).
У каждого узлового объекта DOM есть свойство
nodeType, содержащее цифровой
код, определяющий тип узла.
У обычных элементов он равен 1, что также
определено в виде свойства-константы document.ELEMENT_NODE.
У текстовых
узлов, представляющих отрывки текста, он равен 3 (document.TEXT_NODE).
У комментариев — 8 (document.COMMENT_NODE).
|
kmp
|