
- •1 Подключение скриптов
- •2 Основы языка javascript
- •2.1 Введение
- •2.2 Дата и время
- •2.3 Команда onMouseOver
- •2.4 Еще несколько обработчиков событий
- •2.5 Запрос пользователю и переменные
- •2.6 Создание функции
- •2.7 Команды onUnload и onMouseOut
- •2.7 Новые окна
- •2.8 Новые окна через функцию
- •Это делает скрипт
- •2.9 Метод confirm (введение в if и else)
- •2.10 Смена картинки через onMouseOver
- •2.11 Смена картинок через функции
- •2.12 Функция внутри формы
- •2.13 Поля форм и свойство value
- •2.14 Передача данных в функцию
- •Разбор скрипта начнем с элементов формы:
- •2.15 Слайд-шоу
- •2.16 Проверка данных, введенных в форму
2.3 Команда onMouseOver
Мы обсудили объекты и методы. Теперь приступим к событиям (events). События (event) и обработчики событий (event handler) относятся к JavaScript, но они скорее «встроены» в HTML-код, а не существуют самостоятельно, как те скрипты, которые мы с вами разбирали. Они входят в структуру документа НТМL, не требуя команд <SCRIPT> и </SCRIPT>. Сами они не скрипты, а скорее область взаимодействия между вашей страницей и читателем. События - это то, что происходит. Они добавят динамики вашему сайту. Среди разнообразных обработчиков событий для начала мы выберем один, самый популярный, - onMouseOver (навести мышь).
Рассмотрим скрипт:
<A HREF="http://www.newmail.ru" onMouseOver="window.status='Бесплатный хостинг'; return true">Ссылка</A>
Во-первых, onMouseOver представляет собой обработчик событий (Event Handler) гипертекстовой ссылки. Он используется внутри гиперссылки, формат ссылки остается без изменений. Те же команды и те же двойные кавычки. onMouseOver ставится сразу же после адреса URL. Событие (Event) приводится в действие, когда браузер распознает onMouseOver="". Схема уже должна казаться вам знакомой: два элемента, разделенных точкой. До сих пор это означало, что один является объектом, а другой методом. Но не в этом случае. Объектом является window (окно), оно существует; status (статус) представляет собой property (свойство) окна. Это небольшой участок окна, где должен разместиться следующий текст. Это проще запомнить, если представить, что метод обычно выражается глаголом, как write (писать) или get (получить). Свойство выражается существительным и существует как небольшая часть элемента, стоящего перед точкой. Если у window есть изменяемое свойство status, значит, можно изменить и другие свойства окна.
После window.status следует знак равенства = и то, что должно произойти. В данном случае это текст в одинарных кавычках. Он появится в строке состояния, когда вы наведете курсор на ссылку. Пожалуйста, обратите внимание на точку с запятой в конце строки.
return true - эти два слова имеют не последнее значение. Они дают скрипту указание проверить, есть ли строка состояния. Если отчет (return) соответствует действительности (true), тогда происходит событие. Обратите внимание, что текст в строке состояния уже не изменяется и не изменится, сколько раз вы не наводили бы на нее курсор. Поэтому не нужно злоупотреблять такими трюками — человек, пришедший к вам на сайт, имеет право знать точный адрес каждой ссылки и другую информацию о загрузке страницы, которую выдает строка состояния.
Другие свойства
Вернемся к свойствам. Если они есть у окна, другие объекты тоже должны иметь свойства. Как насчет цвета фона? В HTML цветом фона страницы управляет команда BGCOLOR. То же самое и здесь, только обязательно соблюдайте регистр. В JavaScript он пишется bgColor. Подумаем, как создать ссылку, которая изменяла бы фон страницы с помощью обработчика onMouseOver.
1. Во-первых, раз это ссылка, то сохраним ту же схему, которой уже пользовались.
2. Что мы меняем окно или документ? Куда идет команда bgColor, когда вы пишете веб-страницу? В документ. Значит, это и есть нужный нам объект. Заменим window на document.
3. Мы собираемся менять фоновый цвет объекта, потому заменим status на bgColor.
4. Больше нам текст не нужен, так что заменим его цветом. Возьмем белый.
5. Нам нужно, чтобы новый цвет оставался независимо от того, сколько раз мы будем наводить курсор на ссылку, потому вставляем return true после точки с запятой.
Вот что у нас получилось:
<a href="http://www.newmail.ru" onMouseOver="document.bgColor='white'; return true">Не щелкать</a>
А если мы хотим и то, и другое?
-
Здравый смысл подсказывает, что нужно написать две команды onMouseOver. Попробуем.
-
Мы хотим, чтобы два события произошли одновременно, поэтому не будем разделять команды точкой с запятой, так как это означает конец.
-
Новое правило: ставьте запятую, чтобы отделить друг от друга разные команды JavaScript, происходящие одновременно.
-
Помните, в кавычки ставятся отдельные элементы вроде текста. Раз нам нужно, чтобы обе команды действовали одновременно, ставим кавычки в самом начале первой и в самом конце второй. Таким образом, мы показываем браузеру, что все это одно событие.
-
Однако нам еще могут понадобиться одинарные кавычки.
Вернем документу первоначальный цвет.
<a href="http://www.newmail.ru" onMouseOver="document.bgColor='334775', onMouseOver=window.status='Бесплатная почта'; return true">Не щелкать</a>
Полный код страницы приведен в примере 2.3, а результат выполнения скрипта показан на рис.2.3.
Пример 2.3. Изменение цвета фона |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>Изменение цвета фона</TITLE> </HEAD> <BODY text=#334775 vLink=#fbbcac aLink=#d0550b link=#fbbcac bgColor=#334775> <P align=center> <A href="http://jsp.newmail.ru/les4.htm" onmouseover="document.bgColor='white';" return true>Пример первый: Не щелкать</A> <P align=center> <A href="http://jsp.newmail.ru/les4.htm" onmouseover="document.bgColor='334775', onMouseOver=window.status='Бесплатная почта'; return true">Пример второй: Не щелкать</A> <P align=center><BIG> <A href="" onmouseover="document.bgColor='FC2762', onMouseOver=window.status='каждый'; return true">каждый</A> <A href="" onmouseover="document.bgColor='FB992D', onMouseOver=window.status='охотник'; return true">охотник</A> <A href="" onmouseover="document.bgColor='F9F92F', onMouseOver=window.status='желает'; return true">желает</A> <A href="" onmouseover="document.bgColor='2BFD30', onMouseOver=window.status='знать'; return true">знать,</A> <A href="" onmouseover="document.bgColor='2DF5FB', onMouseOver=window.status='где'; return true">где</A> <A href="" onmouseover="document.bgColor='2969FE', onMouseOver=window.status='сидит'; return true">сидит</A> <A href="" onmouseover="document.bgColor='CE29FE', onMouseOver=window.status='фазан'; return true"onmouseout="document.bgColor='black'">фазан</A> </BIG> </BODY> </HTML>
|
Метод alert() (предупредить) вызывает небольшое диалоговое окно с текстом и кнопкой OK. В примере 2.4 показано, как сделать, чтобы окно предупреждения всплывало при наведении курсора на ссылку (рис.2.4).
Пример 2.4. Вызов окна предупреждения |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <HTML> <HEAD> <TITLE>Вызов окна предупреждения</TITLE> </HEAD> <BODY> <P align=center><A href="http www.newmail.ru" onmouseover="alert('Вызов окна предупреждения')" true return; >Жми сюда.</A> </BODY> </HTML>
|