Фреймы
Фреймы – это прямоугольные области экрана, каждая из которых содержит свой собственный HTML-документ. Фреймы прекрасно подходят для оформления следующих документов:
- Оглавление. Если вы поместите на Web-страницу оглавление в виде вертикального столбца, то пользователь сможет обратиться к нему в любой момент, и ему не нужно будет постоянно щелкать на кнопке возврата к предыдущей странице. Поскольку, находясь во фрейме, оглавление всегда будет под рукой, пользователю нужно будет просто выбрать другой его пункт и сразу же получить нужную информацию.
- Неподвижные элементы интерфейса. Можно зафиксировать на экране какое-то графическое изображение, например, логотип фирмы, в то время как остальная часть страницы будет прокручиваться в другом фрейме.
- Формы и результаты. Можно создать форму в одном фрейме, а в другом отобразить результаты запроса.
Тег <FRAMESET>
Тег <FRAMESET> - заменяет тег <BODY> и используется для разделения экрана. Имеет закрывающий тег.
Атрибуты
- COLS. Делит экран по вертикали. Принимает значения в пикселях, в процентах или просто *. Значение * говорит о том, что конкретный столбец будет занимать всю остальную часть экрана
- ROWS. Делит экран по горизонтали. Принимает значения в пикселях, в процентах или просто *. Значение * говорит о том, что конкретная строка будет занимать всю остальную часть экрана
- FRAMEBORDER. Определяет наличие рамок, т.е. границ фреймов. Принимает значения "yes" или "no".
- BORDER. Определяет ширину рамки в пикселях.
- BORDERCOLOR. Определяет цвет рамок. По умолчанию (если используется стандартная цветовая схема системы Windows) границы фреймов имеют тусклый, серый оттенок. Но при желании можно выбрать любой другой цвет. При определении цвета можно выбрать как его название, так и числовой эквивалент в системе RGB. Например, BLUE или #0000FF.
В отдельном теге <FRAMESET> имеет смысл использовать только один из атрибутов – COLS или ROWS. Это означает, что фреймовая структура будет состоять или только из столбцов, или только из строк. Чтобы создать строки внутри столбцов или столбцы внутри строк, вам потребуется вложенные контейнеры <FRAMESET>…</FRAMESET>.
Пример
<FRAMESET COLS="25%,75%" FRAMEBORDER="YES" BORDER="2">
<FRAMESET ROWS="50%,50%" FRAMEBORDER="YES" BORDER="2">
</FRAMESET>
<FRAMESET ROWS="10%,90%" FRAMEBORDER="YES" BORDER="2">
</FRAMESET>
</FRAMESET>
Используя сразу оба атрибута – и COLS, и ROWS в одном теге <FRAMESET>, вы не сможете получить такое разбиение экрана.
Пример
<FRAMESET COLS="25%,75%" ROWS="50%,50%">
</FRAMESET>
Результат:
1 |
2 |
3 |
4 |
Обратите внимание также на различие в порядке нумерации фреймов.
Тег <FRAME>
Тег <FRAME>, помещенный в контейнер <FRAMESET>…</FRAMESET>, определяет, что именно должно отображаться в конкретном фрейме. Не имеет закрывающего тега.
Атрибуты
- SRC. Определяет URL, связанный с конкретным фреймом.
- MARGINWIDTH. Определяет расстояние между содержимым фрейма и его границами справа и слева.
- MARGINHEIGHT. Определяет расстояние между содержимым фрейма и его границами сверху и снизу.
- SCROLLING. Определяет присутствие в окне фрейма полосы прокрутки. Может принимать значения "yes", "no" и "auto"(по умолчанию).
- NORESIZE. Определяет границы фрейма как "жестко закрепленные" и не позволяет пользователю изменить размеры окна фрейма. Причем фиксируются размеры всех фреймов, имеющих с закрепленным общую границу.
- FRAMEBORDER, BORDER, BORDERCOLOR. Эти атрибуты связаны с рамками и аналогичны таким же в теге <FRAMESET>.
- NAME. Определяет имя окна фрейма. Единственный атрибут, не влияющий на внешний вид фрейма. Позволяет контролировать процесс загрузки фреймов. Если окно фрейма имеет уникальное имя, то к нему можно непосредственно обратиться из других фреймов. Присваивая имена окнам фреймов, надо помнить об одном ограничении: имя не должно начинаться с символа подчеркивания "_", иначе оно будет игнорироваться. Так как с этого символа начинаются некоторые служебные имена.
Пример
<FRAMESET COLS="25%,75%" FRAMEBORDER="yes" BORDER="5" BORDERCOLOR="#008800">
<FRAME src="left.htm" MARGINWIDTH="20" MARGINHEIGHT="20">
<FRAME src="right.htm" NAME="main_window" MARGINWIDTH="0" SCROLLING="no" NORESIZE>
</FRAMESET>
Использование тега A для загрузки во фрейм
С помощью тега гиперссылки <A> можно загрузить документ в определенный фрейм.
Атрибуты
- HREF. Определяет URL или имя нового документа, который вы хотите загрузить в определенное окно фрейма.
- TARGET. Определяет имя фрейма, в который будет загружен новый документ. Это имя должно быть присвоено фрейму атрибутом NAME в теге <FRAME>.
В следующем примере экран разбивается на две вертикальные области. В меньшей левой части находится оглавление, а в правую будут загружаться все остальные HTML-документы. В файле оглавления находятся простые текстовые гиперссылки на соответствующие разделы. Чтобы все работало, необходимо создать HTML-документы в файлах cosm.htm, eat.htm, perf.htm, massage.htm и manic.htm.
Пример
<!-- Файл фреймовой структуры frame.htm --> <HTML> <FRAMESET COLS="25%,75%" FRAMEBORDER="yes" BORDER="5" > <FRAME src="left.htm" NAME="toc_window"> <FRAME src="right.htm" NAME="main_window"> </FRAMESET> </HTML>
<!-- Файл оглавления left.htm -->
<HTML>
<H3>Оглавление</H3>
<UL>
<LI> Товары
<UL>
<LI><A href="cosm.htm" TARGET="main_window"> Косметика</A>
<LI><A href="eat.htm" TARGET="main_window">Пищевые добавки</A>
<LI><A href="perf.htm" TARGET="main_window">Парфюмерия</A>
</UL></LI>
<LI>Услуги
<UL>
<LI><A href="massage.htm" TARGET="main_window">Массаж</A>
<LI><A href="manic.htm" TARGET="main_window">Маникюр</A>
</UL></LI>
</UL>
</BODY>
</HTML>
<!-- Файл заставки основного окна right.htm -->
<HTML>
<BODY>
<H1>Здравствуйте!</H1>
</BODY>
</HTML>
Тег <BASE>
Тег <BASE> избавит вас от необходимости повторять атрибут TARGET в каждой отдельной гиперссылки, если все они указывают на одно и то же окно фрейма. Для этого надо поместить тег <BASE> с атрибутом TARGET в контейнер <HEAD>…</HEAD>.
Использование тега <BASE> даст возможность уменьшить размер файла оглавления left.htm предыдущего примера.
Пример
<!-- Файл оглавления left.htm -->
<HTML>
<HEAD>
<BASE TARGET="main_window">
</HEAD>
<H3>Оглавление</H3>
<UL>
<LI>Товары
<UL>
<LI><A href="cosm.htm">Косметика</A>
<LI><A href="eat.htm">Пищевые добавки</A>
<LI><A href="perf.htm">Парфюмерия</A>
</UL>
<LI>Услуги
<UL>
<LI><A href="massage.htm">Массаж</A>
<LI><A href="manic.htm">Маникюр</A>
</UL>
</UL>
</BODY>
</HTML>
Атрибут TARGET каждой конктерной ссылки замещает одноименный атрибут тега <BASE>.
Пример
<!-- Файл фреймовой структуры frame.htm -->
<HTML>
<FRAMESET COLS="20%,40%,*" FRAMEBORDER="yes" BORDER="5">
<FRAME src="left.htm" NAME="toc_window">
<FRAME src="wares.htm" NAME="wares_window">
<FRAME src="service.htm" NAME="service_window">
</FRAMESET>
</HTML>
<!-- Файл оглавления left.htm -->
<HTML>
<HEAD>
<BASE TARGET="wares_window">
</HEAD>
<H3>Оглавление</H3>
<UL>
<LI>Товары
<UL>
<LI><A href="cosm.htm">Косметика</A>
<LI><A href="eat.htm">Пищевые добавки</A>
<LI><A href="perf.htm">Парфюмерия</A>
</UL>
<LI>Услуги
<UL>
<LI><A href="massage.htm" TARGET="service_window">Массаж</A>
<LI><A href="manic.htm" TARGET="service_window">Маникюр</A>
</UL>
</UL>
</BODY>
</HTML>
<!-- Файл заставки окна товаров wares.htm -->
<HTML>
<BODY>
<H1>Здесь товары!</H1>
</BODY>
</HTML>
<!-- Файл заставки окна услуг service.htm -->
<HTML>
<BODY>
<H1>Здесь услуги!</H1>
</BODY>
</HTML>
Специальные эффекты, получаемые с помощью атрибута TARGET
Как уже упоминалось, имена фреймов не могут начинаться с символа подчеркивания, так как с него начинаются служебные имена, передающие броузеру особую информацию. Ниже перечислены специальные имена, каждое из которых используется для достижения определенного эффекта.
- TARGET="_blank". Документ загружается в новое окно броузера.
- TARGET="_self". Документ загружается в текущее окно.
- TARGET="_parent". Документ загружается в родительский фрейм. Обычно это фрейм, стоящий в контейнере <FRAMESET>…</FRAMESET> перед текущим. Если родительского фрейма нет, то значение "_parent" становится тождественным "_self".
- TARGET="_top". Документ загружается в самый верхний фрейм.
В основном эти служебные имена предназначены для того, чтобы тем или иным способом "вырваться" из текущей фреймовой структуры. Поэкспериментируйте с ними, чтобы понять, как можно загружать документы в различные окна.
Тег <IFRAME>
В HTML 4.0 появились плавающие (или встроенные) фреймы. С помощью тега <IFRAME> можно поместить один фрейм в обычный HTML-документ. Причем контейнер <FRAMESET>…</FRAMESET> здесь не нужен.
Закрывающий тег </IFRAME> обязателен!
Атрибуты
- ALING. Определяет вид выравнивания. Принимает значения "left", "center", "right".
- HEIGHT. Определяет высоту фрейма в пикселях
- WIDTH. Определяет ширину фрейма в пикселях.
- SRC, MARGINWIDTH, MARGINHEIGHT, SCROLLING, FRAMEBORDER, BORDER, BORDERCOLOR, NAME. Аналогичны рассмотренным ранее.
<html>
<body>
<iframe src ="http://www.w3schools.com/" width="100%" height="300">
<p>Your browser does not support iframes.</p>
</iframe>
</body>
</html>
Тег <NOFRAMES>
Определяет, что будет показано в окне браузера если он не поддерживает фреймы.
<NOFRAMES> Ваш браузер не поддерживает плавающие фреймы! </NOFRAMES>