JavaScript. Подробное руководство, 6-е издание
Шрифт:
Из всех этих свойств наибольший интерес представляет свойство
referrer
: оно содержит URL-адрес документа, содержащего ссылку, которая привела пользователя к текущему документу. Это свойство можно было бы использовать, как показано ниже:
if (document.referrer.indexOf(" http://www.google.com/search ?") == 0) {
var args = document.referrer.substring(ref.index0f("?")+1).split("&");
for(var і = 0; і < args.length; i++) {
if (args[і].substrings,2) == "q=") {
document.write("flo6po пожаловать, пользователь Google. ");
document.write("Вы искали: " +
unescape(args[i]. substring^)). replace(' + ', ' ');
break;
}
}
}
Метод
document.write,
использованный в этом примере, является темой следующего раздела. 15.10.2. Метод document.write
Метод
document.write
был одним из первых методов, реализованных еще в вебброузере Netscape 2. Он появился еще до создания модели DOM и представлял единственный способ отображения динамически изменяемого текста в документе. В современных сценариях надобность в этом методе отпала, но вы наверняка встретите его в существующем программном коде. Метод
document.write
объединяет свои строковые аргументы и вставляет получившуюся строку в документ, в точку вызова метода. По завершении выполнения сценария броузер выполнит синтаксический анализ сгенерированного вывода и отобразит его. Например, следующий фрагмент использует метод write
для динамического вывода информации в статический HTML-документ:
<script>
document.write("3arоловок документа: " + document.title);
document.write("<br>URL: " + document.URL);
document.write("<br>Ссылающийся на него документ: " + document, referrer);
document.write("<br>изменен: " + document.lastModified);
document.write("<br>Открыт: " + new Date);
</script>
Важно понимать, что метод
write
можно использовать для вывода разметки 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, в котором свойство innerHTML
указанного элемента обертывается простыми методами write
и close.
Пример 15.10. Интерфейс потоков ввода-вывода к свойству innerHTML
// Определить простейший интерфейс "потоков ввода/вывода” для свойства innerHTML элемента
function ElementStream(elt) {
if (typeof elt === "string”) elt = document.getElementByld(elt);
this.elt = elt; this.buffer = "”;
}
// Объединяет все аргументы и добавляет в буфер
ElementStream.prototype.write = function {
this.buffer += Array.prototype.join.call(arguments,
};
// To же, что и write, но добавляет символ перевода строки
ElementStream.prototype.writeln = function {
this.buffer += Array.prototype.join.call(arguments, "") + "\n";
};
// Переносит содержимое буфера в элемент и очищает буфер.
ElementStream.prototype.close = function {
this.elt.innerHTML = this.buffer; this.buffer = "";
};
Поделиться:
Популярные книги
Личный аптекарь императора. Том 2
2. Личный аптекарь императора
Фантастика:
городское фэнтези
попаданцы
аниме
5.00
рейтинг книги
Запечатанный во тьме. Том 1. Тысячи лет кача
1. Хроники Арнея
Фантастика:
уся
эпическая фантастика
фэнтези
5.00
рейтинг книги
Первый среди равных. Книга VI
6. Первый среди Равных
Фантастика:
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Черный Маг Императора 12
12. Черный маг императора
Фантастика:
юмористическое фэнтези
попаданцы
аниме
сказочная фантастика
фэнтези
5.00
рейтинг книги
Первый среди равных. Книга V
5. Первый среди Равных
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Страж Кодекса. Книга VII
7. КО: Страж Кодекса
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Бастард Императора. Том 14
14. Бастард Императора
Фантастика:
городское фэнтези
аниме
фэнтези
попаданцы
5.00
рейтинг книги
Викинг
1. Викинг
Приключения:
исторические приключения
8.92
рейтинг книги
Газлайтер. Том 9
9. История Телепата
Фантастика:
фэнтези
попаданцы
5.00
рейтинг книги
Чайлдфри
Любовные романы:
современные любовные романы
6.51
рейтинг книги
На границе империй. Том 10. Часть 1
Вселенная EVE Online
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
Последний реанорец. Том I и Том II
1. Высшая Речь
Фантастика:
фэнтези
7.62
рейтинг книги
Чужак из ниоткуда
1. Чужак из ниоткуда
Фантастика:
попаданцы
альтернативная история
5.00
рейтинг книги
Рядовой. Назад в СССР. Книга 1
1. Второй шанс
Фантастика:
попаданцы
альтернативная история
5.00