После достаточно долгого изучения создания HTML‑документов самих по себе, после изучения каскадных таблиц стилей и того, как добавляются и действуют сценарии в документах, наконец‑то рассмотрим применение описанных ранее технологий на примере создания веб‑сайта.
Рта глава посвящается непосредственно разработке Рё реализации веб‑сайта. Р’ следующей главе представлена довольно полезная информация, которая может пригодиться РїСЂРё публикации разработанного сайта РІ Рнтернете.
14.1. Содержание сайта
В начале определимся с содержанием сайта. Пусть это будет информационный ресурс, посвященный... яблокам. Да, это будет своеобразный сайт любителей яблок. Не столько важна тематика сайта, сколько решения, которые будут применены при его реализации.
Ртак, наш информационный ресурс Рѕ яблоках будет содержать следующую информацию (РєСЂРѕРјРµ стартовой страницы Рё страницы информации Рѕ сайте):
• краткая история развития яблочной культуры;
• информация о пищевых свойствах яблок;
• информация о сборе и хранении яблок;
• информация о сортах яблок;
• рецепты приготовления различных блюд с использованием яблок.
Рнформация будет РїРѕ большей части текстовой, Р° также немного таблиц. Нужно уделить РѕСЃРѕР±РѕРµ внимание представлению рецептов блюд так, чтобы сайт можно было без проблем использовать как справочник РїРѕ этим рецептам. Кстати, предположительно, что рецепты Р±СѓРґСѓС‚ составлять РѕСЃРЅРѕРІРЅСѓСЋ долю информации, представленной РЅР° сайте.
14.2. Навигация по сайту
Для навигации по сайту будет использован усовершенствованный вариант всплывающего меню, рассмотренного в предыдущей главе. Меню организуем вверху страницы. Оно будет содержать следующие пункты.
• Главная (переход на главную страницу, файл index.html).
• Рнформация, содержит следующие пункты:
В·В Рстория (файл history.html);
· Пищевая ценность яблок (файл values.html);
· Сбор и хранение яблок (файл collectsave.html).
• Сорта яблок, содержит следующие пункты:
· Летние (файл summer.html);
· Осенние (файл autumn.html);
· Зимние (файл winter.html);
· Позднезимние (файл deepwinter.html).
• Рецепты, содержит следующие пункты:
· Салаты с яблоками (файл salat.html);
· Супы с яблоками (файл soup.html);
· Мясные блюда с яблоками (файл meat.html);
· Рыбные блюда с яблоками (файл fish.html).
• О проекте (переход на страницу с информацией о сайте, файл about.html).
Внешний вид меню навигации показан на рис. 14.1. Реализация меню будет рассмотрена позже.
Рис. 14.1. Внешний вид меню навигации
14.3. Расположение файлов
Теперь определимся с тем, какие папки будут созданы и как в них будут располагаться файлы, используемые для сайта. Сразу отметим, что стартовый файл – index.html.
Пусть рассматривается папка, в которой находится сайт. Тогда ее содержимое можно представить следующим списком:
• все HTML‑файлы сайта (index.html, history.html и т. д.);
• папка с именем css, в которой находятся используемые таблицы стилей;
• папка с именем script, в которой находятся все используемые сценарии;
• папка с именем apples, в которой находятся иллюстрации – картинки яблок (для чего они, см. далее).
В следующем разделе будет пояснено, почему все HTML‑файлы сайта помещаются в одну папку, а не группируются в папки по своей тематике.
14.4. Реализация сайта
Шаблон и внешний вид страниц
Ртак, внешний РІРёРґ страниц строится РЅР° РѕСЃРЅРѕРІРµ таблиц. Чтобы сделать наполнение страниц сайта как можно менее трудоемким, разработан HTML‑файл шаблонной страницы (шаблон.html), его содержимое приведено РІ примере 14.1.
Пример 14.1. Содержимое файла шаблон.html
<!DOCTYPE HTML PUBLIC В«-//W3C//DTD HTML 4.01 Transitional//ENВ»>
<HTML>
<HEAD>
<TITLE>Шаблон</TITLE>
<META name = "Keywords" content = "яблоки, яблоневая культура,
история, сорта яблок, сорт яблок, рецепты, сбор, хранение">
<META http-equiv = "Content-Type" content = "text/html;
charset=utf-8">
<LINK type = "text/css" href = "css/menu.css" rel = "stylesheet">
<LINK type = "text/css" href = "css/page.css" rel = "stylesheet">
<SCRIPT type = "text/javascript" src = "script/popup_menu.js"></SCRIPT>
</HEAD>
<BODY onClick = "hide_menu();">
<A id = "_start"></A>
<!–Вставка строки меню–>
<SCRIPT type = "text/javascript" src = "script/create_menu.js"></SCRIPT>
<TABLE class = "main_table">
<COL width = "70" class = "info">
<COL width = "*" class = "content">
<TR>
<TD class = "info">
<!–Здесь содержится дополнительная информация, реклама и др.
Загружается сценарием–>
<SCRIPT type = "text/javascript" src = "script/load_info.js"></SCRIPT>
</TD>
<TD class = "content">
<!–Далее идет содержимое страницы–>
</TD>
</TR>
<TR class = "copyright">
<TD colspan = "2">
<!–Рнформация РѕР± авторском праве Рё РґСЂ. Загружается сценарием–>
<SCRIPT type = "text/javascript" src = "script/copyright.js"></SCRIPT>
</TD>
</TR>
</TABLE>
</BODY>
</HTML>
Чтобы сделать из приведенного в примере 14.1 файла страницу на конкретную тему, достаточно изменить название страницы, а также добавить на нее содержимое (место вставки содержимого указано HTML‑комментарием). Страница шаблона выглядит так, как показано на рис. 14.2.
Рис. 14.2. Внешний вид страницы шаблона
Как можно заметить, РєСЂРѕРјРµ названия страницы, собственно текста страницы, Р° также расположения Рё размера главной таблицы, формирующей интерфейс страницы, ключевых слов Рё элементов, подключающих сценарии Рё таблицы стилей, РІ файлах создаваемого сайта нет жестко заданной информации. Рто сделано для того, чтобы максимально облегчить последующую модификацию всех страниц сайта: меню, информация РѕР± авторских правах, информация РІ левой колонке формируются соответствующими сценариями РїСЂРё загрузке страниц.
Вообще для большей универсальности можно было бы поручить отдельному сценарию полностью формировать раздел HEAD документа (кроме содержимого элемента TITLE), а еще одному сценарию доверить формирование элемента BODY документа (кроме, естественно, содержимого страницы).
Однако Р·Р° достигнутую СЃ помощью сценариев универсальность надо платить, прежде всего тем, что пользователи, браузеры которых РЅРµ поддерживают сценарии (что, однако, сегодня встречается крайне редко), СЃРјРѕРіСѓС‚ увидеть только текстовое наполнение страниц. РРј будет недоступно меню, без которого РІ данной реализации сайта недоступна навигация.
Чтобы такого не случилось, можно добавить, например, в начало и конец текста каждой страницы гиперссылку на дополнительную страницу сайта, в которой содержится оглавление в виде гиперссылок. Тогда пользователь «ущербного» браузера сможет перемещаться по страницам сайта. Если же браузер пользователя поддерживает сценарии, то упомянутые гиперссылки целесообразно скрывать, для чего им можно присвоить идентификаторы, например index1, index2, а в один из файлов сценариев вставить следующие строки:
index1.style.display = В«noneВ»;
index2.style.display = "none";
Ртак, после рассмотрения файла шаблона страниц сайта можно назвать первую причину, РїРѕ которой РІСЃРµ файлы помещаются РІ РѕРґРЅРѕР№ папке, – это отсутствие необходимости изменения значений атрибутов РІ тегах