Фреймы

Фреймы – это прямоугольные области экрана, каждая из которых содержит свой собственный html-документ. Фреймы использовались для оформления следующих документов:

  • Оглавление. Если вы поместите на Web-страницу оглавление в виде вертикального столбца, то пользователь сможет обратиться к нему в любой момент, и ему не нужно будет постоянно щелкать на кнопке возврата к предыдущей странице. Поскольку, находясь во фрейме, оглавление всегда будет под рукой, пользователю нужно будет просто выбрать другой его пункт и сразу же получить нужную информацию.
  • Неподвижные элементы интерфейса. Можно зафиксировать на экране какое-то графическое изображение, например, логотип фирмы, в то время как остальная часть страницы будет прокручиваться в другом фрейме.
  • Формы и результаты. Можно создать форму в одном фрейме, а в другом отобразить результаты запроса.

Обычные фреймы на данный момент считаются устаревшей технологией и не поддерживаются в HTML5. Не используйте обычные фреймы в своих проектах! В HTML5 тегов frame, frameset и noframes уже просто нет, вместо них предусмотрен один единственный тег iframe (встроенный или плавающий фрейм).

Тег <frameset>

Тег <frameset> заменяет тег <body> и используется для разделения экрана. Имеет закрывающий тег.

Атрибуты тега <frameset>

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>

РЕЗУЛЬТАТ:

1 3
 
 
 
 
2 4
 
 
 
 

Используя сразу оба атрибута – и cols, и rows в одном теге <frameset>, вы не сможете получить такое разбиение экрана.

Пример
<frameset cols="25%,75%" rows="50%,50%" frameborder="yes" border="2"></frameset>

РЕЗУЛЬТАТ:

1 2
3 4

Обратите внимание также на различие в порядке нумерации фреймов.

Тег <frame>

Тег <frame>, помещенный в контейнер <frameset>…</frameset>, определяет, что именно должно отображаться в конкретном фрейме. Не имеет закрывающего тега.

Атрибуты тега <frame>

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.html" marginwidth="20" marginheight="20">
    <frame src="right.html" 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 -->
...
<frameset cols="25%,75%" frameborder="yes" border="5" >
    <frame src="left.htm" name="toc_window">
    <frame src="right.htm" name="main_window">
</frameset>
...

<!-- Файл оглавления left.htm -->
...
<h3>Оглавление</h3>
<ul>
    <li>
        Товары
        <ul>
            <li><a href="cosm.htm" target="main_window">Косметика</a></li>
            <li><a href="eat.htm" target="main_window">Пищевые добавки</a></li>
            <li><a href="perf.htm" target="main_window">Парфюмерия</a></li>
        </ul>
    </li>
    <li>
        Услуги
        <ul>
            <li><a href="massage.htm" target="main_window">Массаж</a></li>
            <li><a href="manic.htm" target="main_window">Маникюр</a></li>
        </ul>
    </li>
</ul>
...

<!-- Файл заставки основного окна right.htm -->
...
<h1>Здравствуйте!</h1>
...

Тег <base>

Тег <base> избавит вас от необходимости повторять атрибут target в каждой отдельной гиперссылке, если все они указывают на одно и то же окно фрейма. Для этого надо поместить тег <base> с атрибутом target в контейнер <head></head>.

Использование тега <base> даст возможность уменьшить размер файла оглавления left.htm предыдущего примера.

Атрибут target каждой конкретной ссылки замещает одноименный атрибут тега <base>.

Пример
<!-- Файл фреймовой структуры frame.htm -->
...
<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>
...

<!-- Файл оглавления left.htm -->
...
<head>
    <base target="main_window">
</head>
...
<h3>Оглавление</h3>
<ul>
    <li>
        Товары
        <ul>
            <li><a href="cosm.htm">Косметика</a></li>
            <li><a href="eat.htm">Пищевые добавки</a></li>
            <li><a href="perf.htm">Парфюмерия</a></li>
        </ul>
    </li>
    <li>
        Услуги
        <ul>
            <li><a href="massage.htm">Массаж</a></li>
            <li><a href="manic.htm">Маникюр</a></li>
        </ul>
    </li>
</ul>
...

<!-- Файл заставки окна товаров wares.htm -->
...
<h1>Здесь товары!</h1>
...

<!-- Файл заставки окна услуг service.htm -->
...
<h1>Здесь услуги!</h1>
...

Специальные эффекты, получаемые с помощью атрибута target

Как уже упоминалось, имена фреймов не могут начинаться с символа подчеркивания, так как с него начинаются служебные имена, передающие браузеру особую информацию. Ниже перечислены специальные имена, каждое из которых используется для достижения определенного эффекта.

  • target="_blank" - документ загружается в новую вкладку браузера;
  • target="_self" - документ загружается в текущую вкладку;
  • target="_parent" - документ загружается в родительский фрейм. Обычно это фрейм, стоящий в контейнере <frameset>…</frameset> перед текущим. Если родительского фрейма нет, то значение "_parent" становится тождественным "_self";
  • target="_top" - документ загружается в самый верхний фрейм.

В основном эти служебные имена предназначены для того, чтобы тем или иным способом "вырваться" из текущей фреймовой структуры. Поэкспериментируйте с ними, чтобы понять, как можно загружать документы в различные окна.

Тег <iframe>

С помощью тега <iframe> можно поместить один фрейм в обычный html-документ. Закрывающий тег </iframe> обязателен!

Атрибуты тега <iframe>

align
Вид выравнивания. Принимает значения "left", "center", "right"
allowtransparency
Прозрачный фон фрейма, через который виден фон страницы
frameborder
Наличие границы вокруг фрейма
height
Высота фрейма в пикселях
hspace
Отступ слева и справа от фрейма до окружающего контента
loading
Возможность отложить загрузку содержимого фрейма до момента, пока до них не дойдет прокрутка. Возможные значения:
  • auto – браузер сам определяет порядок загрузки;
  • eager – загрузка происходит немедленно;
  • lazy – отложенная загрузка закадрового фрейма.
Использование loading="lazy" увеличивает скорость загрузки сайта.
marginheight
Отступ сверху и снизу от содержания до границы фрейма
marginwidth
Отступ слева и справа от содержания до границы фрейма
name
Имя фрейма
sandbox
Ограничения на контент, загружаемый во фрейм
scrolling
Способ отображения полосы прокрутки во фрейме
seamless
Содержимое фрейма должно отображаться так, словно оно является частью документа
src
Путь к файлу, содержимое которого будет загружаться во фрейм
srcdoc
Хранит содержимое фрейма непосредственно в атрибуте
vspace
Отступ сверху и снизу от фрейма до окружающего контента
width
Ширина фрейма в пикселях
<iframe src="banner.html" width="468" height="60" hspace="10" vspace="10" align="center" src="aa.htm">
    Ваш браузер не поддерживает плавающие фреймы!
</iframe>

Тег <noframes>

Определяет, что будет показано в окне браузера, если он не поддерживает фреймы.

<noframes>
    Ваш браузер не поддерживает фреймы!
</noframes>

Как загрузить фрейм без дополнительных файлов?

Чтобы загрузить фрейм без использования внешних файлов, необходимо положить в переменную html-код фрейма, а затем в качестве SRC тега <Iframe> указать "javascript:parent.имя переменной".

<script type="text/javascript">
var varframe = "<html><body> html-код </body></html>";
</script>
...
<iframe src="javascript:parent.varframe"></iframe>

Проблема адресной строки при фреймовой структуре сайта

При использовании фреймов на сайте используется одна страница, которая указывает местоположение фреймов.

Приведём пример такой страницы:

<html>
<head>
    <title> ...  </title>
</head>
<frameset rows="60px,*">
   <frame name="menu" src="Навигационное меню.html">
   <frame name="main" src="Информационная часть.html">
</frameset>
<noframes>
</noframes>
</html>

После загрузки этой страницы происходит загрузка информации во фреймы. Внутри этих фреймов происходят все переходы пользователя по страницам сайта. В адресной строке всегда отображается только путь к начальной странице, который не изменяется при переходах. Посетитель не знает, где он находится в данный момент.

Если посетитель сразу попадает не на главную страницу сайта (например, из поисковика), то это не приводит к воссозданию общей структуры фреймов. Это является причиной того, что владелец сайта не может указать адрес на внутреннюю страницу сайта.

Есть несколько путей решения этой проблемы

Ранее был рассмотрен пример фреймовой структуры. Будем рассматривать различные способы решения этой проблемы именно на нём.

Идея заключается в следующем: при загрузке страницы, содержащей информационную часть, будем проверять окружение страницы и, если требуемая фреймовая структура отсутствует - создадим её при помощи скрипта.

Возможны три случая:

  1. посетитель зашёл на страницу, содержащую фреймовую структуру;
  2. посетитель зашёл на одну из информационных страниц;
  3. посетитель попал на страницу с навигационным меню.

В первом случае после выполнения проверки никаких действий не требуется. Второй и третий практически идентичны, поэтому далее будем рассматривать только второй случай.

Итак, посетитель попадает "куда не надо". В самое начало страницы вставляем скрипт, который будет создавать фреймовую структуру.

Реализация решения возможна как на стороне клиента, так и на стороне сервера.

JavaScript-решение

При таком подходе есть ограничение - не все браузеры поддерживают JavaScript, а в ряде случаев пользователи сами отключают скрипты.

Вначале проверяем окружение страницы, а затем, в случае отсутствия требуемой фреймовой структуры, создаём её.

Создадим файл frame.js:

if (window.name != "main")
    {     window.name="root";
         document.write("<frameset rows='60px,*'>");
         document.write("<frame name='menu' src='menu.html'>");
         document.write("<frame name='main' src='"+URL+"?'>");
         document.write("</frameset>");
    }

Вначале мы проверяем название окна, в который загружается страница: if (window.name != "main"). Если имя окна и название фрейма не совпадают, значит надо создать фреймовую структуру. Это делается динамически с использованием метода write объекта document.

К каждой странице сайта подключаем файл frame.js. Теперь страницы сайта будут иметь такую структуру:

<html>
 <head>
      ...
 </head>
 <script language="JavaScript" src="frame.js"> </script>
 <body>
       ...
</body>
</html>

При таком подходе к решению данной задачи исчезает необходимость в файле, содержащем фреймовую структуру.

PHP-решение

При таком подходе сайт станет доступным большему числу посетителей.

Проверять окружение страницы будем по другому (не так, как при использовании JavaScript). Загрузку документа во фрейм будем выполнять с параметром frames=yes. При открытии страницы проверяем этот параметр, и в случае необходимости динамически создаём фреймовую структуру. Ниже приведён код, который за это отвечает.

<?php
$frame=$HTTP_GET_VARS['frame'];
if ((!isset($frame))||($frame!='yes'))   {
?>
<frameset rows="60px,*">
<frame name="menu" src="menu.php">
<frame name="main" src="index.php?frame=yes">
</frameset>
<noframes>
</noframes>
<?php  } ?>

Помещаем код в файл frames.php. Теперь необходимо подключить его к каждой странице сайта. Ниже приведён пример такой страницы.

<html>
<head>
<title>frames</title>
</head>
<?php
require('frames.php');
?>
<body>
...
</body>
</html>

В данном случае, как и при реализации на стороне клиента нет необходимости отдельно создавать html документ, описывающий фреймовую структуру.

Посмотреть примеры работы с фреймами и как использовать DIV вместо iframe

Читать дальше: Формы в html


.