Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Окружение DOM.docx
Скачиваний:
6
Добавлен:
20.04.2015
Размер:
481.25 Кб
Скачать

Ссылки вверх и вниз

Для комфортного перемещения по узлам существуют дополнительные свойства, указывающие вверх, вниз, на соседей и т.п.

FirstChild и lastChild

Свойства firstChild и lastChild обеспечивают быстрый доступ к первому и последнему потомку.

Например, для документа:

<html><body><div>...</div><ul>...</ul><div>...</div></body></html>

Почему документ в одну строчку? Да потому что если добавить пробелов, то первым и последним узлами будут не элементы, а пробельные узлы.

Вот в этом документе firstChild и lastChild будут указывать уже не на узлы-элементы, а на текстовые, пробельные узлы:

<html>

<body>

<div>...</div>

<ul>...</ul>

<div>...</div>

</body>

</html>

В любом случае firstChild и lastChild — это более быстрый и короткий способ обратиться к первому и последнему элементам childNodes. Верны равенства:

body.firstChild === body.childNodes[0]

body.lastChild === body.childNodes[body.childNodes.length-1]

parentNode, previousSibling и nextSibling

  • Свойство parentNode ссылается на родительский узел.

  • Свойства previousSibling и nextSibling дают доступ к левому и правому соседу.

Ниже изображены ссылки между BODY и его потомками документа:

<!DOCTYPE HTML>

<html>

<head><meta charset="utf-8"></head>

<body>

<div>Начало</div>

<ul>

<li>Содержание</li>

</ul>

<div>Конец</div>

</body>

</html>

Ссылки (пробельные узлы обозначены решеткой #):

Все навигационные ссылки — только для чтения. При изменениях DOM, добавлении или удалении элементов они обновляются автоматически.

Задание

Напишите самый короткий код для проверки, пуст ли элемент elem. «Пустой» — значит нет дочерних узлов, даже текстовых.

Решение

Вначале нерабочие способы, которые могут прийти на ум:

if (!elem) { .. }

Это не работает, так как elem всегда есть, и является объектом. Так что проверка if (elem) всегда верна, вне зависимости от того, есть ли у elem потомки.

if (!elem.childNodes) { ... }

Тоже не работает, так как псевдо-массив childNodes всегда существует. Он может быть пуст или непуст, но он всегда является объектом, так что проверка if (elem.childNodes) всегда верна.

Несколько рабочих способов:

if (!elem.childNodes.length) { ... }

if (!elem.firstChild) { ... }

if (!elem.lastChild) { ... }

Вопрос

Если elem — это произвольный узел DOM…

Верно ли, что elem.lastChild.nextSibling всегда null?

Верно ли, что elem.children[0].previousSibling всегда null ?

Свойства узлов: тип, тег, содержимое и другие

три основных свойства DOM-узлов: тип, тег и содержимое

Тип: nodeType

С тремя типами мы уже встречались. Это 1) элемент, 2) текстовый узел и 3) комментарий.

На самом деле типов узлов гораздо больше. Строго говоря, их 12, и они описаны в спецификации DOM Уровень 1:

interface Node {

// NodeType

const unsigned short ELEMENT_NODE = 1;

const unsigned short ATTRIBUTE_NODE = 2;

const unsigned short TEXT_NODE = 3;

const unsigned short CDATA_SECTION_NODE = 4;

const unsigned short ENTITY_REFERENCE_NODE = 5;

const unsigned short ENTITY_NODE = 6;

const unsigned short PROCESSING_INSTRUCTION_NODE = 7;

const unsigned short COMMENT_NODE = 8;

const unsigned short DOCUMENT_NODE = 9;

const unsigned short DOCUMENT_TYPE_NODE = 10;

const unsigned short DOCUMENT_FRAGMENT_NODE = 11;

const unsigned short NOTATION_NODE = 12;

...

}

Нам важны номера основных типов.

Самые важные — это ELEMENT_NODE под номером 1 и TEXT_NODE под номером 3.

Тип узла содержится в его свойстве nodeType.

Например, выведем все узлы-потомки document.body, являющиеся элементами:

<!DOCTYPE html>

<html>

<head>

<title> </title>

</head>

<body>

<div>Читатели:</div>

<ul>

<li>Вася</li>

<li>Петя</li>

</ul>

<!-- комментарий -->

<script>

var childNodes = document.body.childNodes;

for (var i=0; i<childNodes.length; i++) {

// отфильтровать не-элементы

if (childNodes[i].nodeType != 1) continue;

alert(childNodes[i]);

}

</script>

</body>

</html>

Результат

Читатели:

  • Вася

  • Петя

Что выведет скрипт на этой странице?

<!DOCTYPE HTML>

<html>

<body>

<script>

alert(document.body.lastChild.nodeType);

</script>

</body>

</html>

Решение

Небольшой подвох — в том, что во время выполнения скрипта последним тегом является SCRIPT. Браузер не может обработать страницу дальше, пока не выполнит скрипт.

Так что результат будет 1 (узел-элемент).