Фреймы – хорошо или плохо?

Фреймы давно являются предметом спора. У них есть сторонники и противники(последних больше). Сначала рассмотрим положительные моменты. Используя фреймы легко создавать навигационные меню, структурировать отображаемую информацию, сократить время загрузки страницы, т.к. общие элементы загружаются только один раз. Теперь посмотрим на недостатки. Такая конструкция сайта не позволяет полноценно использовать META-данные, а также, что не менее важно, возникает проблема адресной строки.
Проблема адресной строки
Рассмотрим проблему адресной строки. Её суть в следующем. При использовании фреймов на сайте используется одна страниц, которая указывает местоположение фреймов.
Приведём пример такой страницы:
<HTML>
 <HEAD> 
   <TITLE> 
   </TITLE> 
  </HEAD> 
 <FRAMESET ROWS="60px,*”>
  <FRAME name=”menu”  SRC="Навигационное меню.html">
  <FRAME name=”main” SRC="Информационная часть.html">
 </FRAMESET>
 <NOFRAMES>
 </NOFRAMES>
</HTML>
После загрузки этой страницы происходит загрузка информации во фреймы. Внутри этих фреймов происходят все переходы пользователя по страницам сайта. В адресной строке всегда отображается только путь к начальной странице, который не изменяется при переходах. Посетитель не знает, где он находится в данный момент.

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

Несмотря на сложность ситуации, эта проблема не является неразрешимой. Тем, кому интересно, предлагаю перейти к обзору решений.Решение проблемы есть

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

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

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

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

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

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

Реализация решения возможна как на стороне клиента, так и на стороне сервера. Основной недостаток реализации на стороне клиента очевиден – зависимость от возможностей и настроек клиента. Например, на компьютере пользователя запрещено выполнение скриптов. Второй вариант не будет работать, если на сервере нет поддержки PHP и ASP.

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

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

Создадим файл framesunits.js, в котором будет содержаться функция TestFrames. Она будет выполнять все необходимые действия.
function TestFrames(URL)
{
  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.

К каждой странице сайта подключаем файл framesunits.js и вызываем функцию TestFrames. Теперь страницы сайта будут иметь такую структуру:
<html>
<head>
    ...
</head>
<script language="JavaScript" src="framesunits.js">
</script>
<script language="JavaScript">
   TestFrames(document.URL);
</script>
<body>
    ...
</body>
</html
При таком подходе к решению данной задачи исчезает необходимость в файле, содержащем фреймовую структуру. PHP-решение
Для реализации решения проблемы адресной строки на стороне сервера воспользуемся 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 документ, описывающий фреймовую структуру.

Среди тех, кто знает как заставить работать фреймы должным образом, меньше противников фреймов.

URL: https://visavi.net/articles/290