В поле location отображается URL загруженного документа. Если пользователь хочет вручную перейти к какой-либо странице (набрать ее URL), он делает это в поле location. Поле располагается в верхней части окна браузера ниже панели инструментов, но выше панели личных предпочтений.
Рис. 14.2. Поле Location
Вообще говоря, Location — это объект. Из-за изменений в версиях JavaScript класс Location входит как подкласс и в класс Window, и в класс Document. Мы будем рассматривать Location только как window.location. Кроме того, Location — это еще и подкласс класса URL, к которому относятся также объекты классов Area и Link. Location наследует все свойства URL, что позволяет получить доступ к любой части схемы URL.
Рассмотрим характеристики и способы использования объекта Location:
свойства;
методы;
событий, характеризующих Location, нет.
Как мы видим, список характеристик объекта Location неполный.
Предположим, что браузер отображает страницу, расположенную по адресу:
http://intuit.ru:80/r/dir/page?search#mark
Тогда свойства объекта Location примут следующие значения:
Методы Location предназначены для управления загрузкой и перезагрузкой страницы. Это управление заключается в том, что можно либо перезагрузить документ (reload), либо загрузить (replace). При этом в трассу просмотра страниц (history) информация не заносится:
Метод reload() полностью моделирует поведение браузера при нажатии на кнопку Reload в панели инструментов. Если вызывать метод без аргумента или указать его равным true, то браузер проверит время последней модификации документа и загрузит его либо из кеша (если документ не был модифицирован), либо с сервера. Такое поведение соответствует простому нажатию на кнопку Reload. Если в качестве аргумента указать false, то браузер перезагрузит текущий документ с сервера, несмотря ни на что. Такое поведение соответствует одновременному нажатию на Reload и кнопку клавиатуры Shift (Reload+Shift).
Метод replace() позволяет заменить одну страницу другой таким образом, что это замещение не будет отражено в трассе просмотра HTML-страниц (history), и при нажатии на кнопку Back из панели инструментов пользователь всегда будет попадать на первую загруженную обычным способом (по гипертекстовой ссылке) страницу. Напомним, что при изменении свойств Location также происходит перезагрузка страниц, но в этом случае записи об их посещении в history пропадают.
История посещений (History)
История посещений (трасса) страниц World Wide Web позволяет пользователю вернуться к странице, которую он просматривал несколько минут (часов, дней) назад. История посещений в JavaScript трансформируется в объект класса history. Этот объект указывает на массив URL-страниц, которые пользователь посещал и которые он может получить, выбрав из меню браузера режим GO. Методы объекта history позволяют загружать страницы, используя URL из этого массива.
Чтобы не возникло проблем с безопасностью браузера, путешествовать по History можно, только используя индекс URL. При этом URL, как текстовая строка, программисту недоступен. Чаще всего этот объект используют в примерах или страницах, на которые могут быть ссылки из нескольких разных страниц, предполагая, что можно вернутся к странице, из которой пример будет загружен:
Данный код отображает кнопку "Назад", нажав на которую мы вернемся на предыдущую страницу.
Тип браузера (объект Navigator)
В связи с войной браузеров (которая, можно считать, уже закончилась в пользу Microsoft Internet Explorer) стала актуальной задача настройки страницы на конкретную программу просмотра. При этом возможны два варианта: определение типа браузера на стороне сервера и определение типа браузера на стороне клиента. Для последнего варианта в арсенале объектов JavaScript существует объект Navigator. Этот объект — свойство объекта Window.
Рассмотрим простой пример определения типа программы просмотра:
При нажатии на кнопку отображается окно предупреждения. В нем содержится строка userAgent, которую браузер помещает в соответствующий HTTP-заголовок.
Эту строку можно разобрать по компонентам, например:
navigator.appName = Microsoft Internet Explorernavigator.appCodeName = Mozillanavigator.appVersion = 4.0 (compatible; MSIE 5.5; Windows 98)navigator.userAgent = Mozilla/4.0 (compatible; MSIE 5.5; Windows 98)
Листинг 14.1.
У объекта Navigator есть еще несколько интересных с точки зрения программирования применений. Например, проверка поддержки Java.
Проиллюстрируем эту возможность на примере:
<SCRIPT>
document.write("<P ID=red>");if(navigator.javaEnabled()==true) document.write("Ваша программа поддерживает исполнение Java-апплетов");if(navigator.javaEnabled()==false) document.write("<FONT COLOR=red>Ваша программа не поддерживает исполнение Java-апплетов</FONT>");</SCRIPT></example>
Листинг 14.2.
Аналогично можно проверить форматы графических файлов, которые поддерживает ваш браузер:
<SCRIPT>if(navigator.mimeTypes['image/gif']!=null) document.write("Ваш браузер поддерживает GIF<BR>");if(navigator.mimeTypes['image/tif']==null) document.write("Ваш браузер не поддерживает TIFF");</SCRIPT>
Листинг 14.3.
К сожалению, такая проверка не позволяет определить наличие автоматической подгрузки графики.
Что можно сделать с окном? Открыть (создать), закрыть (удалить), положить его поверх всех других открытых окон (передать фокус). Кроме того, можно управлять свойствами окна и свойствами подчиненных ему объектов. Описанию основных свойств посвящен раздел "Программируем свойства окна браузера", поэтому сосредоточимся на простых и наиболее популярных методах управления окнами:
alert();
confirm();
prompt();
open();
close();
focus();
setTimeout();
clearTimeout().
Здесь не указаны только два метода: scroll() и blur().
Первый позволяет прокрутить окно на определенную позицию. Но его очень сложно использовать, не зная координат окна. Последнее является обычным делом, если только не используется технология программирования слоев или CSS (Cascading Style Sheets).
Второй метод уводит фокус с окна. При этом совершенно непонятно, куда этот фокус будет передан. Лучше целенаправленно передать фокус, чем просто его потерять.
window.alert()
Метод alert() позволяет выдать окно предупреждения:
Все очень просто, но нужно иметь в виду, что сообщения выводятся системным фонтом, следовательно, для получения предупреждений на русском языке нужна локализованная версия ОС.
window.confirm()
Метод confirm() позволяет задать пользователю вопрос, на который тот может ответить либо положительно, либо отрицательно:
Введенную пользователем строчку можно присвоить любой переменной и потом разбирать ее в JavaScript-программе.
window.open()
У этого метода окна атрибутов больше, чем у некоторых объектов. Метод open() предназначен для создания новых окон. В общем случае его синтаксис выглядит следующим образом:
где: URL — страница, которая будет загружена в новое окно, window_name — имя окна, которое можно использовать в атрибуте TARGET в контейнерах A и FORM.
Таблица 2.
Параметры
Назначение
replace
Позволяет при открытии окна управлять записью в массив History
param
Список параметров
width
Ширина окна в пикселах
height
Высота окна в пикселах
toolbar
Создает окно с системными кнопками браузера
location
Создает окно с полем location
directories
Создает окно с меню предпочтений пользователя
status
Создает окно с полем статуса status
menubar
Создает окно с меню
scrollbars
Создает окно с полосами прокрутки
resizable
Создает окно, размер которого можно будет изменять
При нажатии кнопки "сложное окно" получаем окно, где:
directories=yes - окно с меню
height=200 - высота 200 px
location=yes - поле location есть
menubar=yes - меню есть
resizable=yes - размер изменять можно
scrollbars=yes - есть полосы прокрутки
status=yes - статусная строка есть
toolbar=yes - системные кнопки браузера есть
width=200 - ширина 200
window.close()
Метод close() — это оборотная сторона медали метода open(). Он позволяет закрыть окно. Чаще всего возникает вопрос, какое из окон, собственно, следует закрыть. Если необходимо закрыть текущее, то:
window.close();self.close();
Если необходимо закрыть родительское окно, т.е. окно, из которого было открыто текущее, то:
window.opener.close();
Если необходимо закрыть произвольное окно, то тогда сначала нужно получить его идентификатор:
id=window.open();...id.close();
Как видно из последнего примера, закрывают окно не по имени (значение атрибута TARGET тут ни при чем), а используют указатель на объект.
window.focus()
Метод focus() применяется для передачи фокуса в окно, с которым он использовался. Передача фокуса полезна как при открытии окна, так и при его закрытии, не говоря уже о случаях, когда нужно выбирать окна. Рассмотрим пример.
Открываем окно и, не закрывая его, снова откроем окно с таким же именем, но с другим текстом. Новое окно не появилось поверх основного окна, так как фокус ему не был передан. Теперь повторим открытие окна, но уже с передачей фокуса:
function myfocus(a){id = window.open("","example","scrollbars,width=300,height=200");//открываем окно и заводим переменную с указателем на него//если окно с таким именем существует, то новое окно не создается,//а открывается поток для записи в окно с этим именемif(a==1){id.document.open();//открываем поток ввода в уже созданное окноid.document.write("<CENTER>>Открыли окно в первый раз");//Пишем в этот поток}if(a==2){id.document.open();id.document.write("<CENTER>Открыли окно во второй раз");}if(a==3){id.focus();//передаем фокус, затем выполняем те же действия, что и в предыдущем случаеid.document.open();id.document.write("<CENTER>Открыли окно в третий раз");}id.document.write("<FORM><INPUT TYPE=button onClick='window.close();' VALUE='Закрыть окно'></CENTER>");id.document.close();}
Листинг 14.5.
Поскольку мы пишем содержание нового окна из окна старого (родителя), то в качестве указателя на объект используем значение переменной id.
window.setTimeout()
Метод setTimeout() используется для создания нового потока вычислений, исполнение которого откладывается на время (ms), указанное вторым аргументом:
idt = setTimeout("JavaScript_код",Time);
Типичное применение этой функции — организация автоматического изменения свойств объектов. Например, можно запустить часы в поле формы:
var flag=0;var idp=null;function myclock(){if(flag==1){d = new Date();window.document.c.f.value = d.getHours()+":"+d.getMinutes()+":"+d.getSeconds();}idp=setTimeout("myclock();",500);}function flagss(){if(flag==0) flag=1; else flag=0;}...<FORM NAME=c>Текущее время:<INPUT NAME=f size=8><INPUT TYPE=button VALUE="Start/Stop"onClick="flagss();myclock();"></FORM>
Листинг 14.6.
Нужно иметь в виду, что поток порождается всегда, даже в том случае, когда часы стоят. Если бы он создавался только при значении переменной flag равном единице, то при значении 0 он исчез бы, тогда при нажатии на кнопку часы продолжали бы стоять.