можно использовать для вывода разметки HTML только в процессе синтаксического анализа документа. То есть вызывать метод
document.write
из программного кода верхнего уровня в теге
<script>
можно только в случае, если выполнение сценария является частью процесса анализа документа. Если поместить вызов
document.write
в определение функции и затем вызвать эту функцию из обработчика события, результат окажется неожиданным - этот вызов уничтожит текущий документ и все содержащиеся в нем сценарии! (Почему это происходит, будет описано чуть ниже.) По тем же причинам нельзя использовать
document.write
в сценариях с установленными атрибутами
defer
или
async
.
Пример 13.3 в главе 13 использует метод
document.write
указанным способом чтобы сгенерировать более сложный вывод.
Метод
write
можно использовать для создания полностью новых документов в других окнах и фреймах. (Однако при работе с другими окнами и фреймами необходимо позаботиться о том, чтобы не нарушать политику общего происхождения.) Первый вызов метода
write
другого документа полностью уничтожит имеющееся содержимое этого документа. Метод
write
можно вызывать многократно, тем самым добавляя новое содержимое в документ. Содержимое, передаваемое методу
write,
может буферизоваться (и не отображаться), пока не будет выполнен завершающий вызов метода
close
объекта документа, сообщающий парсеру, что работа с документом окончена и он может выполнить разбор документа и отобразить его.
Следует отметить, что объект
Document
поддерживает также метод
writeln,
который идентичен методу
write,
за исключением того, что он добавляет символ перевода строки после вывода своих аргументов. Это может пригодиться, например, при выводе форматированного текста внутри элемента
<рге>
.
Метод
document.write
редко используется в современных сценариях: свойство
innerHTML
и другие приемы, поддерживаемые моделью DOM, обеспечивают более удачные способы добавления содержимого в документ. С другой стороны, некоторые алгоритмы лучше укладываются в схему потокового ввода/вывода, реализуемую методом
write.
Если вы создаете сценарий, который динамически генерирует и выводит текст в процессе своего выполнения, вам, возможно, будет интересно ознакомиться с примером 15.10, в котором свойство
Иногда удобно иметь возможность определять, какой участок текста документа выделен пользователем. Сделать это можно, как показано ниже:
function getSelectedText {
if (window.getSelection) // Функция, определяемая стандартом HTML5
return window.getSelection.toString;
else
if (document.selection) // Прием, характерный для IE.
return document.selection.createRange.text;
}
Стандартный метод
window.getSelection
возвращает объект
Selection
, описывающий текущий выделенный текст, как последовательность одного или более объектов
Range
. Объекты
Selection
и
Range
определяют чрезвычайно сложный прикладной интерфейс, который практически не используется и не описывается в этой книге. Наиболее важной и широко реализованной (везде, кроме IE) особенностью объекта
Selection
является его метод
toString,
который возвращает простое текстовое содержимое выделенной области.
Броузер IE определяет иной прикладной интерфейс, который не описывается в этой книге. Метод
document.selection
возвращает объект, представляющий выделенную область. Метод
createRange
этого объекта возвращает реализованный только в IE объект
TextRange
, свойство
text
которого содержит выделенный текст.
Прием, подобный приведенному в примере выше, в частности, может пригодиться в букмарклетах (раздел 13.2.5.1) для организации поиска выделенного текста в поисковых системах или на сайте. Так, следующая HTML-ссылка пытается отыскать текущий выделенный фрагмент текста в Википедии. Если поместить в закладку эту ссылку и URL-адрес со спецификатором javascript:, закладка превратится в букмарклет: