12.1. Организация рабочего окружения
12.2. Внедрение сценариев в HTML-документ
12.3. Вводим первый сценарий
12.4. Разбор нашего сценария в среде FrontPage
12.5. Отладка сценария в Microsoft Script Editor
Вы познакомились с синтаксическими конструкциями и операторами языкаJavaScript, теперь перейдем непосредственно к созданию сценариев. В данной главе вы узнаете, что вам понадобится для создания сценариев. Кроме того, будут рассмотрены способы внедрения сценариев в HTML-документы. Потом для примера вы создадите простой сценарий, на котором и рассмотрите процесс создания сценариев JavaScript.
12.1. Организация рабочего окружения
Для успешной работы в какой-либо области важно иметь под рукой необходимые инструменты, и будет лучше, если они будут удобными. В работе по созданию сценариев также необходимо хоть немного, но организовать свое рабочее место. В этом разделе мы как раз и займемся кратким освещением вопросов, связанных с организацией рабочего окружения.
Текстовые редакторы
Для работы над сценариями подойдет практически любой текстовый редактор, позволяющий создавать обычные текстовые файлы и сохранять их в формате HTM или HTML. Например, в операционной системе Windows в числе стандартных есть два подходящих текстовых редактора – это Блокнот и WordPad. Отдельно стоит отметить редактор Microsoft Word из пакета Microsoft Office – он никак не подойдет для создания сценариев. По умолчанию данный редактор сохраняет свои файлы в двоичном виде, которые ничего общего с веб-страницами не имеют. Хотя можно сохранять его файлы и как веб-страницы, он не позволяет напрямую работать с кодом страниц, а значит, вы не сможете создавать в нем сценарии.
Существуют редакторы, специально разработанные для создания веб-страниц, например Microsoft FrontPage или Adobe Dreamweaver (ранее известный как Macromedia Dreamweaver). Такие редакторы позволяют создавать веб-страницы с помощью визуальных инструментов, а затем уже переключаться в режим отображения кода и вносить какие-либо нестандартные изменения, например добавлять сценарии. Если же создавать с их помощью обычные веб-страницы сможет даже пользователь, не владеющий языком разметки HTML, то вносить изменения в режиме работы с кодом сможет только человек, хотя бы немного знакомый с этим языком. По этой причине пользователям, еще только начинающим разбираться с HTML, следует применять данные редакторы лишь в режиме работы с кодом, чтобы полностью контролировать ход создания веб-страниц. По сравнению с обычными текстовыми редакторами в Microsoft FrontPage или Adobe Dreamweaver синтаксис языков HTML и JavaScript подсвечивается. Таким образом, в них будет удобно работать над сценариями.
РљСЂРѕРјРµ того, РІ Рнтернете можно найти большое количество РґСЂСѓРіРёС… текстовых редакторов, которые позволяют создавать веб-страницы Рё РїСЂРё этом РјРѕРіСѓС‚ подсвечивать синтаксис языков HTML Рё JavaScript, Р° также имеют РјРЅРѕРіРѕ иных полезных возможностей, которые существенно упрощают процесс создания веб-страниц Рё разработки сценариев. РњРЅРѕРіРёРµ такие редакторы распространяются бесплатно или условно бесплатно, Рё, возможно, какой-РЅРёР±СѓРґСЊ РёР· РЅРёС… придется вам РїРѕ душе.
Браузеры
Вы собираетесь создавать сценарии, управляющие веб-страницами, поэтому для проверки работоспособности этих документов вам понадобится какой-либо браузер. Как известно, полной совместимости среди браузеров нет, а значит, проверив работоспособность своего творения в одном браузере, нельзя быть уверенным в работоспособности в других. Следовательно, лучше использовать как можно большее количество различных браузеров для проверки своих веб-страниц.
Р’ РѕСЃРЅРѕРІРЅРѕРј веб-разработчикам приходится считаться СЃ особенностями браузера Internet Explorer, который РЅРµ слишком стремится Рє стандартам. Поэтому обязательно тестируйте СЃРІРѕРё веб-страницы РЅР° данном браузере, присутствующем РІ каждой версии операционной системы Windows. Большой популярностью также пользуются браузеры Mozilla Firefox Рё Opera, которые стремятся максимально соответствовать стандартам. Вообще можно встретить Рё РґСЂСѓРіРёРµ браузеры, например Konqueror Сѓ пользователей операционной системы Linux или Safari Сѓ пользователей операционной системы Mac OS. Что касается браузеров РѕС‚ независимых производителей, то РѕРЅРё стараются строго соответствовать стандартам, избегая фирменных возможностей браузеров компаний Microsoft Рё Netscape. Можно прийти Рє выводу, что для проверки работоспособности СЃРІРѕРёС… сценариев будет вполне достаточно трех браузеров: Internet Explorer, Mozilla Firefox Рё Opera. Причем первый РёР· перечисленных браузеров есть Сѓ всех пользователей операционной системы Windows, Р° следующие РґРІР° можно без проблем загрузить РёР· Рнтернета. Браузер Mozilla Firefox можно загрузить СЃ сайта , Р° Opera – СЃ сайта . РљСЂРѕРјРµ того, РЅРµ РІСЃРµ пользователи работают СЃ последними версиями браузеров, поэтому для максимального охвата интернет-аудитории может потребоваться тестирование документов РЅР° младших версиях указанных браузеров.
Отладчики сценариев JavaScript
Отладка представляет собой поиск и устранение ошибок. Часто процесс отладки может занимать большую часть времени разработки всей программы (или сценария). Ведь надежность и безошибочная работа программы зачастую даже важнее ее функциональности. Поэтому для облегчения и ускорения отладки созданы специальные программы, которые называются отладчиками. Типичный отладчик имеет такие возможности, как пошаговое выполнение программы с остановкой в каждой строке кода или в заранее отмеченных для этого точках остановки, а также возможность отслеживания и изменения значений каждой переменной прямо во время выполнения программы.
Стоит отметить, что для программистов на таких языках, как, например, C++ или Java, отладчики стали таким же обычным и привычным инструментом, как, например, текстовый редактор. А вот для разработки сценариев на JavaScript отладчики применялись не всегда ввиду того, что сценарии, как правило, имели небольшой размер и малую сложность и поэтому могли быть проверены и вручную. Однако в настоящее время сценарии на JavaScript, особенно с использованием технологии AJAX, уже не уступают по объему кода и сложности программам, написанным на таких языках, как C++ или Java. Поэтому все чаще и чаще при разработке сценариев на JavaScript применяют отладчики. Кроме того, если вы в дальнейшем при разработке своих сценариев на JavaScript столкнетесь с какой-либо ошибкой или неправильной работой сценария, умение пользоваться отладчиком сэкономит вам немало времени и труда.
Существует немало отладчиков для сценариев на JavaScript. Например, Microsoft Script Debugger, бесплатно распространяющийся отладчик от компании Microsoft, который можно загрузить по адресу , имеет все необходимое для успешной отладки сценариев на JavaScript. При отладке сценариев Microsoft Script Debugger применяется совместно с браузером Internet Explorer. Кроме того, данный отладчик распространяется вместе с редактором Microsoft FrontPage в рамках программы Microsoft Script Editor, которая практически не отличается от Microsoft Script Debugger.
Существуют и другие отладчики (например, для браузера Mozilla Firefox), созданные в виде расширений. В частности, отладчик Firebug можно загрузить с сайта . Причем если перейти на данную страницу в браузере Mozilla Firefox, то отладчик сразу же будет установлен.
12.2. Внедрение сценариев в HTML-документ
В данном разделе будут рассмотрены вопросы, касающиеся встраивания сценариев в веб-страницы, поэтому предполагается, что вы хотя бы немного знакомы с языком разметки HTML. Обычно сценарии внедряются в HTML-документ тремя стандартными способами:
• в виде гиперссылки;
• в виде обработчика события;
• в рамках элемента SCRIPT.
Разберем способы встраивания сценариев в веб-страницы по порядку. Начнем с разбора метода встраивания сценария под видом гиперссылки.
Встраивание сценариев в гиперссылку
Как известно, для создания на веб-страницах гиперссылок применяется элемент A, у которого есть атрибут href для указания адреса страницы или файла, куда приведет гиперссылка. Однако вместо адреса данный атрибут может содержать и JavaScript-сценарий, если перед сценарием поставить слово javascript: (со знаком:). Рассмотрим пример такой гиперссылки:
Когда пользователь щелкает кнопкой мыши на гиперссылке, интерпретатор сценариев JavaScript получает следующий код:
alert('Привет, мир!');
Рнтерпретатор исполняет этот РєРѕРґ, РІ результате чего РЅР° экране появляется РѕРєРЅРѕ (СЂРёСЃ.В 12.1).
Рис. 12.1. После перехода по гиперссылке появляется окно
Здесь сценарий состоит из вызова всего одной функции alert(), которая выводит на экран окно с текстом, полученным в качестве параметра. В принципе, объем кода может быть любой. Следует помнить, что, если браузер не поддерживает JavaScript или поддержка этого языка отключена, гиперссылка будет отображена, но работать не будет, что может вызвать недоумение у пользователей. Поэтому во избежание проблем это следует учесть.
Встраивание сценариев для обработки событий
При работе с такой графической операционной системой, как Windows, вы могли заметить, что она всегда готова отреагировать на ваши действия: щелкнули кнопкой мыши на значке программы – программа запустилась, нажали клавишу в текстовом редакторе – появился соответствующий символ и т. д. Все это некие события, которые приходят от мыши, клавиатуры, таймера и многих других устройств. Аналогично и браузер может реагировать на различные события.
Поведение каждого элемента зависит РѕС‚ событий, которые постоянно возникают РІ браузере. Например, пользователь щелкнул РєРЅРѕРїРєРѕР№ мыши РЅР° тексте, переместил указатель мыши, загрузил HTML-документ. Браузер сам решает, как реагировать РЅР° каждое событие. Однако РІС‹ можете перехватывать отдельные события Рё задавать РЅРѕРІРѕРµ поведение РїСЂРё РёС… наступлении. Р’ языке HTML Сѓ РјРЅРѕРіРёС… элементов есть атрибуты, соответствующие различным событиям. Рти атрибуты РјРѕРіСѓС‚ содержать РєРѕРґ языка JavaScript, выполняемый РІ ответ РЅР° событие. Например:
Рто простой текст
Рлемент P просто объединяет текст РІ параграфы, однако РјС‹ возложили РЅР° него еще РѕРґРЅСѓ функцию. Определив атрибут onclick, наш текст будет реагировать РЅР° щелчок РєРЅРѕРїРєРѕР№ мыши (СЂРёСЃ.В 12.2).
Рис. 12.2. После щелчка кнопкой мыши на тексте появляется сообщение
В языке HTML (начиная с версии 4.0) практически каждый элемент имеет атрибуты для обработки каких-либо событий. Для обработки событий данным атрибутам назначается код на языке JavaScript, который выполняется, когда произойдет событие. Благодаря возможности обработки событий вы можете создавать интерактивные страницы, отвечающие на действия пользователей.
Встраивание сценариев в рамках элемента SCRIPT
Кроме возможности обработки событий, для внедрения сценариев в веб-страницы в языке разметки HTML есть специальный элемент SCRIPT. Браузер, встретив тег , как сценарий на каком-либо языке. Для указания языка сценария используется атрибут type.
Например, для указания языка JavaScript:
При использовании сценариев JavaScript можно этот атрибут не указывать, так как значение «text/javascript» является значением по умолчанию.
Кроме того, иногда для указания типа языка используют атрибут language. Так, для указания языка JavaScript 1.0 значение атрибута language должно быть «JavaScript», для JavaScript 1.1 – "JavaScript1. 1", для JavaScript 1.2 – "JavaScript1.2" и т. д. Однако данный атрибут не входит в стандарт, определяющий язык HTML, хотя и распознается большинством браузеров. По этой причине его не рекомендуется употреблять. Стоит заметить, что если значение атрибута language незнакомо браузеру, то содержимое элемента SCRIPT игнорируется.
Если пользователь работает в старой версии браузера, которая не поддерживает JavaScript, то элемент SCRIPT может оказаться неизвестным программе и код сценария будет выведен на экран как обычный текст. Таким образом, необходимо обеспечить маскировку кода сценариев от старых браузеров. Для этого код сценария внутри элемента SCRIPT окружают комментариями языка HTML ():
Таким образом, браузер ранней версии, встретив элемент SCRIPT, проигнорирует его, а содержащийся внутри этого элемента код пропустит, посчитав комментарием.
Здесь стоит обратить внимание, что перед закрывающим комментарием языка HTML (->) стоит еще и комментарий языка JavaScript (//), поскольку иначе при выполнении JavaScript-кода некоторые браузеры могут попытаться выполнить обработку этой строки, а набор символов – > в JavaScript имеет совсем другое значение. Вообще, язык JavaScript богат на различные комбинации символов, обозначающие комментарии. Комментарии игнорируются интерпретатором JavaScript.
Комментарии // и
Комментарии могут быть и многостроковыми, что облегчает отладку сценария и позволяет закомментировать проблемный участок кода. Для этой цели используются наборы символов /* и */.
Что же делать с браузерами, которые не поддерживают сценарии или такая возможность в них просто отключена? В таких случаях необходимо либо предупредить пользователя, что для просмотра требуется поддержка сценариев, либо заменить код каким-либо вариантом без сценариев. Для этого в языке HTML есть элемент NOSCRIPT, чье содержимое будет использовано при отсутствии поддержки сценариев. Например:
Ваш браузер не поддерживает сценариев JavaScript или их поддержка отключена
Таким образом, можно, например, предупредить пользователя Рѕ том, что для просмотра страницы ему необходим браузер СЃ поддержкой JavaScript. Рли же можно предоставить пользователю ссылку РЅР° версию сайта, адаптированную для старых версий браузеров.
Сценарии РјРѕРіСѓС‚ содержаться РІ самой веб-странице, как описано выше, Р° также РІ отдельном файле. Рлемент SCRIPT имеет атрибут src, который должен иметь значение адреса файла СЃРѕ сценарием. Обычно файлы СЃРѕ сценариями JavaScript имеют расширения JS, например файл lib1.js. Таким образом, чтобы подключить Рє HTML-документу файл lib1.js, необходимо добавить РІ него следующую строку:
Ваш браузер не поддерживает сценарии или их поддержка отключена
...
...
Рлемент страницы, события которого обрабатываются
...