— журнал «Доктайп»
❌ Эта статья об устаревшем теге, спецификация HTML не рекомендует использовать его в веб-разработке.
Тег <frameset>
используется для разделения области окна браузера на несколько фреймов, каждый из которых отображает свою веб-страницу.
Синтаксис тега <frameset>
<frameset cols="50%,50%"> <frame src="page1.html"> <frame src="page2.html"> </frameset>
Спецификация HTML
Тег <frameset>
является устаревшим и был удалён из HTML5. Вместо него рекомендуется использовать другие методы, такие как CSS Grid или Flexbox. Последняя версия спецификации, где упоминается этот тег, — это HTML 4.01.
Семантический или нет
Тег <frameset>
не считается семантическим, так как не придаёт никакого конкретного значения содержимому. Он используется для создания разметки страницы, разбивая её на несколько областей, каждая из которых может загружать отдельный HTML-документ.
Примеры использования
Этот пример создаст две колонки: в левой колонке будет отображаться menu.html
, а в правой — content.html
.
<frameset cols="25%,75%"> <frame src="menu.html"> <frame src="content.html"> </frameset>
Здесь в верхней строке будет отображаться заголовок, а в нижней строке — две колонки. В левой окажется menu.html
, а в правой — content.html
.
<frameset rows="25%,75%"> <frame src="header.html"> <frameset cols="25%,75%"> <frame src="menu.html"> <frame src="content.html"> </frameset> </frameset>
Для чего использовать тег <frameset>
- Организовать страницу сайта, когда требуется разбить информацию на несколько частей, отображаемых в одном окне браузера.
- Создать сетку для отображения нескольких веб-страниц на одной странице.
- Создать навигацию, которая всегда находится на месте, независимо от того, какую страницу посетитель сайта просматривает.
- Разместить рекламные блоки, чтобы они всегда оставались на месте при прокрутке страницы.
Атрибуты тега <frameset>
cols
— ширина и количество колонок фреймов внутри<frameset>
. Например,cols="25%, 75%"
создаст две колонки с шириной25%
и75%
соответственно.rows
— высота и количество строк фреймов внутри<frameset>
.border
— толщина рамки вокруг фреймов.framespacing
— расстояние между фреймами.frameborder
— наличие границ вокруг каждого фрейма.name
— имя<frameset>
.
Глобальные атрибуты
Тег поддерживает все глобальные атрибуты HTML.
Ограничения
Тег <frameset>
является устаревшим в HTML5 и больше не поддерживается.
Нюансы
- Использование фреймов может вызывать проблемы с доступностью и SEO-оптимизацией сайта.
- Все страницы, загружаемые во фреймах, должны быть доступными по отдельности.
Поддержка браузерами
Тег <frameset>
поддерживается во всех современных браузерах, но не рекомендуется к использованию, так как этот тег считается устаревшим. Актуальная информация — на caniuse.
Альтернативные теги
Современная веб-разработка нацелена на использование семантических тегов и отказ от использования табличной вёрстки и фреймов в пользу более гибких и удобных способов создания макетов. Тег <frameset>
можно заменить на такие теги, как <div>
, <section>
и другие семантические теги, в зависимости от конкретной задачи.
Чем заменить тег
Если необходимо создать набор окон на странице, то вместо <frameset>
можно использовать технологии современной веб-разработки, такие как CSS Grid или Flexbox.
Пример использования CSS Grid для создания макета страницы. Здесь мы создаём три колонки, в каждую из которых можно поместить контент:
<div> <div>Контент 1</div> <div>Контент 2</div> <div>Контент 3</div> </div>
. grid-container { display: grid; grid-template-columns: 1fr 1fr 1fr; grid-gap: 10px; } .grid-item { background-color: #ffffff; border: 1px solid #cccccc; padding: 10px; }
Актуальность
Тег <frameset>
устарел, не используйте его в веб-разработке.
Хотите узнать больше об HTML-тегах?
Попробовать
«Доктайп» — журнал о фронтенде. Читайте, слушайте и учитесь с нами.
ТелеграмПодкастБесплатные учебники
Фреймы в HTML-документах. Синтаксис фреймов. Планирование фреймов и взаимодействия между фреймами. Комплектная загрузка фреймов.
Фреймы в HTML-документах. Синтаксис фреймов. Планирование фреймов и взаимодействия между фреймами. Комплектная загрузка фреймов.Источники информации — на сайтах www.
codenet.ru и www.javaportal.ru.ФРЕЙМЫ
Каждый фрейм имеет свой URL, что позволяет загружать его независимо от других фреймов. Каждый фрейм имеет собственное имя (параметр NAME), позволяющее переходить к нему из другого фрейма. Размер фрейма может быть изменен пользователем прямо на экране при помощи мыши (если это не запрещено указанием специального параметра). Данные свойства фреймов позволяют создавать интерфейсные решения, как например:
>> Помещение в статическом фрейме оглавления документов, содержащихся на WEB-сервере, что позволяет пользователю быстро находить интересующую его информацию.
>> Создавние окна результатов запросов, когда в одном фрейме находится собственно запрос, а в другом результаты запроса.
Синтаксис фреймов
Формат документа с фреймами напоминает формат обычного документа, только вместо тэга BODY используется контейнер FRAMESET, содержащий описание внутренних HTML-документов с информацией.
<HTML>
<HEAD>...</HEAD>
<FRAMESET>...<FRAMESET>
<HTML>
Однако, фрейм-документ является специфичным видом HTML-документа, поскольку не содержит элемента BODY и какой-либо информационной нагрузки. Он описывает только фреймы, которые будут содержать информацию. Представим общий синтаксис фреймов:
<FRAMESET COLS="value" | ROWS="value">
<FRAME SRC="url1">
<FRAME ...>
. . .
</FRAMESET>
Общий контейнер FRAMESET описывает все фреймы, на которые делится экран. Вы можете разделить экран на несколько вертикальных или несколько горизонтальных фреймов. Тэг FRAME описывает каждый фрейм в отдельности.
Рассмотрим более детально каждый компонент.
FRAMESET
<FRAMESET [COLS="value" | ROWS= "value"]>
Тэг <FRAMESET> имеет завершающий тэг </FRAMESET>. Все, что может находиться между этими двумя тэгами, это тэг <FRAME>, вложенные тэги <FRAMESET> и </FRAMESET>, а также контейнер из тэгов <NOFRAME>, который позволяет строить двойные документы для браузеров, поддерживающих и не поддерживающих фреймы.
Данный тэг имеет два взаимоисключающих параметра: ROWS и COLS. ROWS= «список-определений-горизонтальных-подокон» Данный тэг содержит описания некоторого количества подокон, разделенные запятыми. Каждое описание представляет собой числовое значение размера подокна в пикселях, процентах от всего размера окна или связанное масштабное значение. Количество подокон определяется количеством значений в списке. Общая сумма высот подокон должна составлять высоту всего окна (в любых измеряемых величинах). Отсутствие атрибута ROWS определяет один фрейм, величиной во все окно браузера. COLS=»список-определений-горизонтальных-подокон». То же самое, что и ROWS, но делит окно по вертикали, а не по горизонтали. Внимание! Совместное использование данных параметров может привести к непредсказуемым результатам.
Синтаксис используемых видов описания величин подокон:
value
Простое числовое значение определяет фиксированную высоту подокна в пикселях. Это далеко не самый лучший способ описания высоты подокна, поскольку различные браузеры имеют различный размер рабочего поля. Если вы используете данный способ описания размера, то настоятельно рекомендуется сочетать его с каким-либо другим, чтобы в результате получить 100%-ное заполнение окна.
value%
Значение величины подокна в процентах от 1 до 100. Если общая сумма процентов описываемых подокон превышает 100, то размеры всех фреймов пропорционально уменьшаются до суммы 100%. Если, соответственно, сумма меньше 100, то размеры пропорционально увеличиваются.
value*
Символ «*» указывает на то, что все оставшееся место будет принадлежать данному фрейму. Если указывается два или более фрейма с описанием «*» (например «*,*»), то оставшееся пространство делится поровну между этими фреймами.
Примеры:
<FRAMESET COLS= "50,*,50">
— описывает три фрейма, два по 50 точек справа и слева, и один внутри этих полосок. <FRAMESET ROWS= "20%,3*,*">
<FRAMESET ROWS= "*,60%,*">
— аналогично предыдущему примеру.
Тэги <FRAMESET> могут быть вложенными, т.е. например:
<FRAMESET ROWS="50%,50%">
<FRAMESET COLS="*,*"
</FRAMESET>
</FRAMESET>
FRAME
<FRAME SRC="url" [NAME="frame_name"] [MARGINWIDTH="nw"] [MARGINHEIGHT="nh"] [SCROLLING= yes|no|auto] [NORESIZE]>
Данный тэг определяет фрейм внутри контейнера FRAMESET.
SRC=»url». Описывает URL документа, который будет отображен внутри данного фрейма. Если он отсутствует, то будет отображен пустой фрейм.
NAME=»frame_name». Данный параметр описывает имя фрейма. Имя фрейма может быть использовано для определения действия с данным фреймом из другого HTML-документа или фрейма (как правило, из соседнего фрейма этого же документа). Имя обязательно должно начинаться с символа. Содержимое поименованных фреймов может быть задействовано из других документов при помощи специального атрибута TARGET, описываемого ниже.
MARGINWIDTH=»value». Это атрибут может быть использован, если автор документа хочет указать величину разделительных полос между фреймами сбоку. Значение value указывается в пикселях и не может быть меньше единицы.
MARGINHEIGHT=»value». То же самое, что и MARGINWIDTH, но для верхних и нижних величин разделительных полос.
SCROLLING=»yes | no | auto». Этот атрибут позволяет задавать наличие полос прокрутки у фрейма. Параметр yes указывает, что полосы прокрутки будут в любом случае, параметр no — полос прокрутки не будет. Auto определяет полосу прокрутки только при их необходимости (значение по умолчанию).
NORESIZE. По умолчанию, размер фрейма можно изменить при помощи мыши так же просто, как и размер окна Windows. NORESIZE отменяет данную возможность. Если у одного фрейма установлен атрибут NORESIZE, то у соседних фреймов тоже не может быть изменен размер со стороны данного.
NOFRAMES. Данный тэг используется в случае, если вы создаете документ, который может просматриваться как браузерами, поддерживающими фреймы, так и браузерами, их не поддерживающими. Данный тэг помещается внутри контейнера FRAMESET, а все, что находится внутри тэгов <NOFRAMES> и </NOFRAMES>, игнорируется браузерами, поддерживающими фреймы.
Пример.
Окно браузера разбивается на две равных зоны (верхнюю и нижнюю) по горизонтали. Верхняя зона разбивается на два подокна шириной 65% и 35%, в которые записываются документы link1. html и link2.html. Нижняя зона разбивается на 3 подокна с шириной центрального 40% и с равной шириной боковых окон для документов link3.html, link4.html и link5.html.
<FRAMESET ROWS="*,*"> <NOFRAMES>
<h2>Ваша версия WEB-браузера не поддерживает фреймы!</h2>
</NOFRAMES>
<FRAMESET COLS="65%,35%">
<FRAME SRC="link1.html">
<FRAME SRC="link2.html">
</FRAMESET>
<FRAMESET COLS="*,40%,*">
<FRAME SRC="link3.html">
<FRAME SRC="link4.html">
<FRAME SRC="link5.html">
</FRAMESET>
</FRAMESET>
Планирование фреймов и взаимодействия между фреймами
С появлением фреймов сразу возникает вопрос: «А как сделать так, чтобы нажимая на ссылку в одном фрейме инициировать появление информации в другом?» Ответом на данный вопрос является планирование взаимодействия фреймов (далее — планирование).
Каждый фрейм может иметь собственное имя, определяемое параметром NAME при описании данного фрейма. Существует, также, специальный атрибут — TARGET, позволяющий определять, к какому фрейму относится та или иная операция. Формат данного атрибута следующий:
TARGET=»windows_name».
Данный атрибут может встречаться внутри различных тэгов:
TARGET в тэге A.
Это самое прямое использование TARGET. Обычно, при активизации пользователем ссылки соответствующий документ появляется в том же окне (или фрейме), что и исходный, в котором была ссылка. Добавление атрибута TARGET позволяет произвести вывод документа в другой фрейм. Например:
<A href="mydoc.phpl" TARGET= "Frame1"> Переход в фрейм п 1 </A>
TARGET в тэге BASE.
Размещение TARGET в тэге BASE позволит вам не указывать при описании каждой ссылки фрейм-приемник документов, вызываемых по ссылкам. Это очень удобно, если в одном фрейме у вас находится меню, а в другой — выводится информация. Например:
Документ п 1.
<FRAMESET ROWS="20,*">
<FRAME SRC="doc2.htm" NAME="Frame1">
<FRAME SRC="doc3.htm" NAME="Frame2">
</FRAMESET>
Документ п 2 (doc2.htm).
<HTML><HEAD><BASE TARGET="Frame2"></HEAD>
<BODY>
<A href="url1"> Первая часть</A>
<A href="url2"> Вторая часть</A>
</BODY></HTML>
TARGET в тэге AREA.
Mожно включать тэг TARGET в описание ссылки при создании карты изображения. Например:
<AREA SHAPE="circle" COORDS="100,100,50" href="http://www.softexpress.com" TARGET= "Frame1">
TARGET в тэге FORM.
То же относится и к определению формы. В данном случае, после обработки переданных параметров формы результирующий документ появится в указанном фрейме.
<FORM ACTION="url" TARGET= "window_name">
Внимание! Имя окна (фрейма) в параметре TARGET должно начинаться с латинской буквы или цифры. Также необходимо помнить, что существуют зарезервированные имена для разрешения специальных ситуаций.
Зарезервированные имена фреймов
Зарезервированные имена фреймов служат для разрешения специальных ситуаций. Все они начинаются со знака подчеркивания. Любые другие имена фреймов, начинающиеся с подчеркивания, будут игнорироваться браузером.
TARGET=»_blank»
Данное значение определяет, что документ, полученный по ссылке, будет отображаться в новом окне браузера.
TARGET=»_self».
Данное значение определяет, что документ, полученный по ссылке, будет отображаться в том же фрейме, в котором находится ссылка. Это имя удобно для переопределения окна назначения, указанного ранее в тэге BASE.
TARGET=»_parent».
Данное значение определяет, что документ, полученный по ссылке, будет отображаться в родительском окне, вне зависимости от параметров FRAMESET. Если родительского окна нет, то данное имя аналогично «_self».
TARGET=»_top».
Данное значение определяет, что документ, полученный по ссылке, будет отображаться на всей поверхности окна, вне зависимости от наличия фреймов. Использование данного параметра удобно в случае вложенных фреймов.
Пример загрузки фреймов (фрейм не загружается отдельно от остальных фреймов)
Страница на сайте состоит из нескольких фреймов (fr1.html, fr2.html, fr3.html). В том случае, если посетитель открывает один из фреймов напрямую (допустим, получив ссылку из поискового каталога), JavaScript проверяет, что фрейм открыт отдельно от остальных фреймов и производит перезагрузку таким образом, чтобы страница показывалась с учетом всех фреймов (открывается файл index.html) . Решаем её следующим образом: Создаём index.html файл:
<html>
<frameset rows="33%,33%,34%">
<frame src="fr1.html" name="fr1">
<frame src="fr2.html" name="fr2">
<frame src="fr3. html" name="fr3">
</frameset>
</html>
Как видим фреймы имеют имена fr1, fr2, fr3. При открытии файла fr1.html нам необходимо произвести проверку открыт этот файл во фрейме или нет. Так как мы знаем, что имя фрейма, куда должен загружаться файл — fr1, то проверку делаем следующим образом:
if(this.name!="fr1")document.location="index.html"
Т.е. если документ открывается не во фрейме this.name возвращает пустое значение и открывается файл index.html.
Вот пример файла fr1.html
<html><head><script language="JavaScript">
<!--if(this.name!="fr1")document.location="index.html"//-->
</script></head>
<body><h2>Это первый фрейм</h2></body></html>
Соответственно файл fr2.html выглядит следующим образом:
<html><head><script language="JavaScript">
<!--if(this. name!="fr2")document.location="index.html"//-->
</script></head>
<body><h2>Это второй фрейм</h2></body></html>
Файл fr3.html выглядит следующим образом:
<html><head><script language="JavaScript">
<!--if(this.name!="fr3")document.location="index.html"//-->
</script></head>
<body><h2>Это третий фрейм</h2></body></html>
Используются технологии uCoz
HTML-фреймы и наборы фреймов — изучите примеры
HTML-фреймы используются для разделения окна браузера на несколько прямоугольных секций или фреймов, где каждый фрейм может загружать и отображать отдельный HTML-документ.
Предупреждение: Не используйте тег body при использовании фреймов. Используйте вместо
, а не внутри
. Точно так же никакие другие теги, такие как абзацы и т. д., нельзя использовать вместе с фреймами, кроме как внутри 9.0007