В разделах, посвященных программированию графики, показано, что
картинку можно менять без перезагрузки всей HTML-страницы. К
большому сожалению, изменить часть текста страницы без использования
позиционированных слоев нельзя.
Замечание: начиная с версий 4.0
Microsoft Explorer это стало возможным, но так как здесь речь идет о
классическом JavaScript и его применении к различным объектным
моделям только в одной интерпретации, данную возможность мы
рассматривать не будем.
Кроме графики, на странице есть еще
несколько встроенных массивов объектов, элементы которых
можно изменять. Один из них —
массив гипертекстовых
ссылок.
Гипертекстовая ссылка относится к классу
объектов URL. К этому классу объектов относятся:
Область применения URL на HTML-страницах гораздо шире этих трех позиций. Чаще всего мы сталкиваемся с ним при программировании:
Первые две позиции подробно обсуждаются в разделах "Программируем
картинки" и "Программируем формы". В данном разделе мы
сосредоточимся на программировании собственно гипертекстовых
переходов и "чувствительных" картинок. Но прежде рассмотрим объект
URL.
Объект URL
Объект класса URL обладает
свойствами, которые определены схемой URL. В качестве примера
рассмотрим ссылку на применение атрибута SRC в контейнере
IMG:
http://bourabai.kz/help/index.html
href: |
http://bourabai.kz/help/index.html |
protocol: |
http: |
hostname: |
bourabai.kz |
host: |
bourabai.kz:80 |
port: |
80 |
pathname: |
help/index.html |
search: |
|
hash: |
|
Обращение к свойству объекта класса URL выглядит
как:
имя_объект_класса_URL.свойство
Например,
так:
document.links[0].href
document.location.host
document.links[2].hash
Свойства
объекта URL дают программисту возможность менять только часть URL –
объекта (гипертекстовой ссылки, например). Наиболее
интересно это выглядит в объекте Location , когда при изменении
свойства происходит перезагрузка документа. Однако и при работе с
обычными гипертекстовыми ссылками такая технология более
предпочтительна, чем изменение всего URL целиком.
Здесь следует
заметить, что чаще всего все-таки меняют весь URL. Это связано с
тем, что такое действие более понятно с точки зрения HTML-разметки.
Ведь у контейнера A нет атрибута PROTOCOL, но зато есть атрибут
HREF.
К встроенным гипертекстовым ссылкам
относятся собственно ссылки (<A HREF=...>...</A>) и
ссылки "чувствительных" графических картинок. Они составляют
встроенный массив гипертекстовых ссылок
документа (document.links[]).
К сожалению, обратиться по имени к
гипертекстовой ссылке нельзя. Точнее такое обращение не
рекомендуется в силу различий между браузерами. Поэтому обращаться к
ним можно только как к массиву встроенных ссылок. В
качестве примера распечатаем гипертекстовые ссылки
некоторого
документа:
for(i=0;i<document.links.length;i++)
document.write(document.links[i].href+"<BR>");
Список
ссылок:
http://bourabai.kz/help/index.html
http://bourabai.kz/help/terms.html
http://bourabai.kz/help/shop.html
Вставим
в документ контейнер MAP:
<MAP NAME=test>
<AREA
SHAPE=rect COORDS="0,0,0,0"
HREF="javascript:window.alert('Area_Link_1');void(0);">
<AREA
SHAPE=rect COORDS="0,0,0,0"
HREF="javascript:window.alert('Area_Link_2');void(0);">
</MAP>
И
снова распечатаем массив
ссылок:
links[0]:http://bourabai.kz/help/index.html
links[1]:http://bourabai.kz/help/terms.html
links[2]:http://bourabai.kz/help/shop.html
links[3]:javascript:window.alert('Area_Link_1');void(0);
links[4]:javascript:window.alert('Area_Link_2');void(0);
Две
новые ссылки — это ссылки из контейнера MAP, который не
отображается, но ссылки из него попадают в массив
встроенных ссылок. При этом, как в нашем случае, они могут попасть
между обычными гипертекстовыми ссылками, если контейнер MAP
расположить внутри текста документа. На данной странице он помещен
перед контейнером SCRIPT, в котором мы распечатываем массив
встроенных ссылок.
В разделе "Программируем ссылки" мы перечислили свойства объекта
класса Link. Теперь покажем, как при помощи JavaScript-кода
можно ими управлять. Рассмотрим меню типа "записная книжка
Конечно, это не настоящая "записная книжка". Поле формы
заполняется только при выборе гипертекстовой ссылки,
расположенной над этим полем. Единственная цель данного примера —
показать, как изменяется значение атрибута HREF (оно
отображается в поле status окна браузера). Изменение производится
посредством вызова функции:
В данном случае мы работаем с тремя
элементами массива встроенных гипертекстовых
ссылок: all['lo0'], all['lo1'] и all['lo2']. У каждого из них
при вызове функции со значением аргумента a, равным 0, 1 и 2,
соответственно, изменяем значение свойства href. Это
свойство мы меняем целиком. URL можно менять и
частично.
Гипертекстовая ссылка — это объект класса
URL. У этого объекта можно изменять и другие свойства.
Проиллюстрируем эту возможность при частичном изменении ссылки.
Распечатаем сначала свойство, которое не зависит от протокола (в
нашем случае от javascript) document.all.next.pathname: href:-->
http://bourabai.kz/help/index.html
pathname:-->
help/index.html
Изменим теперь pathname:
document.all.next.pathname="test";
document.write(
window.document.all.next.pathname);
href:-->
http://bourabai.kz:80/test
pathname--> test
Обратите
внимание, что Internet Explorer самостоятельно добавил в ссылку
номер порта. По этой причине использовать свойства, отличные от
href, в ссылках, где используется схема javascript, не
рекомендуется.
Эти два события из всех событий, которые обрабатываются на страницах Web, используются чаще всего. Именно они позволяют обесцвечивать и проявлять картинки, а также менять содержание поля status. Первое событие генерируется браузером, если курсор мыши указывает на гипертекстовую ссылку, а второе — когда он покидает гипертекстовую ссылку. Рассмотрим пример с записной книжкой, но только для проявления меню второго уровня будем использовать обработчик события onMouseover:
<TABLE
BORDER=0 CELLSPACING=1
CELLPADDING=0
ALIGN=center>
<TR>
<TD>
<A
HREF="javascript:void(0);"
onMouseover="line2(0);return
true;">
<IMG SRC=addrpho.gif
BORDER=0></A></TD>
...
</TR>
</TABLE>
В качестве обработчика события мы вызываем функцию line2(), которая
идентична line1() из предыдущего примера. В примере IMG перенесен на
новую строку для наглядности. На самом деле так поступать не следует
— при интерпретации HTML-парсером могут появиться неучтенные
пропуски, которые не предусмотрены автором страницы.
Мы
рассмотрели редкий пример, в котором не требуется возврата
предыдущего значения после прохода мыши по гипертекстовой ссылке. По
этой причине в гипертекстовой ссылке не применялся второй обработчик
onMouseout. В большинстве случаев, например при расцвечивании
картинки, он требуется:
<A
HREF="javascript:void(0);"
onMouseover="document.pic1.src='image2.gif';
return
true;"
onMouseout="document.pic1.src='image.gif';
return
true;">
<IMG NAME=pic1 src=image.gif
BORDER=0></A>
Рассматривая предыдущий пример, мы не
обсудили использование функции return. При работе с графикой
значение, которое возвращает обработчик события, на результат
отображения не влияет. Но если изменять значение поля статуса
браузера, то изменения произойдут только в случае возврата значения
true. Более подробно об этом рассказано в разделе "Поле
статуса".
Обработка события click
Вообще говоря, обработчик
события click в современном JavaScript не нужен. Можно прекрасно
обойтись URL-схемой javascript, которая была специально придумана
для перехвата события гипертекстового перехода. Обработчик onClick
следует рассматривать как реликт, доставшийся нам в наследство от
предыдущих версий языка, который поддерживается в версиях Netscape
Navigator и Internet Explorer.
Основная задача обработчика
данного события — перехват события гипертекстового перехода. Если
функция обработки данного события возвращает значение true, то
переход происходит, при значении false — не происходит:
Отменим
переход в начало страницы описания события обработчика
onClick:
<A HREF=#click onClick=
"window.alert('Нет
перехода на #click');
return false;">onClick</A>
А
теперь дадим пользователю право выбора перехода в начало страницы
посредством окна подтверждения:
<A HREF=#top
onClick=
"return window.confirm(
'Перейти в начало
страницы?');">
переход в начало страницы</A>
Обратите
внимание на место применения функции window.confirm() — аргумент
команды return. Логика проста: функция возвращает значение true или
false, и именно оно подставляется в качестве аргумента. Если просто
написать функцию без return, то ничего работать не будет.
Можно
ли вообще обойтись одним обработчиком onClick без использования
атрибута HREF? Видимо, нет. Первое, что необходимо браузеру — это
определение типа контейнера A. Если в нем есть только атрибут NAME,
то это якорь, если присутствует атрибут HREF — ссылка. Это два
разных объекта. Они имеют различные составляющие, в том числе и
обработчики событий. В контексте текущего раздела нам нужна именно
ссылка, т.е. контейнер A с атрибутом HREF. Проверим наше
предположение:
<A ID=red
onClick="window.alert("тест");return false;">
Нет атрибута
HREF
</A>
Текст "Нет атрибута HREF" — это якорь.
Обработчик на нем не работает, так как на него нельзя указать
мышью.
<A href="#" id=red
onClick="window.alert('URL:'+this.href);
return
false;">
Нет атрибута HREF
</A>
Теперь мы указали
пустую ссылку (см. поле статуса). Содержание окна — это база
URL.
Схема URL- "javascript:..."
Для программирования
гипертекстовых переходов в спецификацию универсального
идентификатора ресурсов (URL) разработчики JavaScript ввели
отдельную схему по аналогии со схемами http, ftp и т.п. —
javascript. Эта схема URL упоминается в разделе "Размещение
JavaScript-кода" в контексте передачи управления
JavaScript-интерпретатору от HTML-парсера. Кроме того, о
программировании гипертекстового перехода рассказано в разделе
"Обработка события click". Теперь мы рассмотрим более общий случай
обработки события гипертекстового перехода при выборе гипертекстовой
ссылки.
Схема URL javascript в общем виде выглядит следующим
образом:
<A
HREF="javascript:...;">...</A>
<FORM
ACTION="javascript:...">
Одним словом, в любом месте, где мы
используем URL, вместо любой из стандартных схем можно применить
схему javascript. Единственное исключение составляет контейнер IMG.
URL в нем используется в атрибуте SRC. Принять определенное значение
SRC может при помощи либо назначения в IMG, либо обращения к
свойству IMG. По большому счету, применение JavaScript в SRC может
только проинициализировать картинку. Дальнейшее ее изменение описано
в разделе "Программируем графику". Рассмотрим пример простой
гипертекстовой ссылки: <A
HREF="javascript:window.alert(
'window.alert() изменяет
HREF');void(0);">
Заменили обычную
ссылку
</A>
Можно выполнить аналогичную операцию, но над
картинкой:
var flag=0;
function
ichange()
{
if(flag==0)
{
document.i1.src="image1.gif";
flag=1;
}
else
{
document.i1.src="image2.gif";
flag=0;
}
}
...
<A
HREF="javascript:ichange();void(0);">
<IMG NAME=i1
SRC=image2.gif BORDER=0>
</A>
Попробуем теперь
выполнить JavaScript-код применительно к контейнеру
FORM:
<FORM NAME=f action="javascript:window.alert(document.f.fi0.value);void(0);" METHOD=post>Введите текст для отображения
в окне и нажмите ввод: <INPUT NAME=fi0 SIZE=20 MAXLENGTH=20>
</FORM>
Следует отметить, что все-таки использование схемы javascript в этом месте HTML-разметки выглядит неудачно. Для того чтобы все работало так, как задумано автором, приходится использовать метод POST. Гораздо логичнее применить обработчик события onSubmit.
Понятие же "физического вакуума" в релятивистской квантовой теории поля подразумевает, что во-первых, он не имеет физической природы, в нем лишь виртуальные частицы у которых нет физической системы отсчета, это "фантомы", во-вторых, "физический вакуум" - это наинизшее состояние поля, "нуль-точка", что противоречит реальным фактам, так как, на самом деле, вся энергия материи содержится в эфире и нет иной энергии и иного носителя полей и вещества кроме самого эфира.
В отличие от лукавого понятия "физический вакуум", как бы совместимого с релятивизмом, понятие "эфир" подразумевает наличие базового уровня всей физической материи, имеющего как собственную систему отсчета (обнаруживаемую экспериментально, например, через фоновое космичекое излучение, - тепловое излучение самого эфира), так и являющимся носителем 100% энергии вселенной, а не "нуль-точкой" или "остаточными", "нулевыми колебаниями пространства". Подробнее читайте в FAQ по эфирной физике.