IFrames (HTML) устарели?
Получать противоречивые сообщения об этом, надеюсь, что нет. Я не могу себе представить, что его поддержка прекратилась бы, поскольку их используют несколько миллиардов сайтов.
Некоторые дополнительные вопросы об этом:
- Почему они должны отказаться от этого тега?
- Есть ли альтернатива?
14 ответов
На мой взгляд, W3C бросил вызов в создании драмфреймов из доктрипов Strict HTML и XHTML. В теории вы бы использовали <object>
элемент для добавления посторонних объектов в ваш документ, но различия и ограничения браузера сделали это незапланированным для многих разработчиков. С гораздо более прагматичным HTML 5 (который все еще является черновиком), iframes вернулись и даже имеют два новых атрибута: seamless
и интригующий sandbox
,
Поддержка для <iframe>
все еще есть в HTML 5, поэтому я не думаю, что это изменится в ближайшем будущем.
Чтобы ответить на другие ваши вопросы:
<iframe>
s (как и фреймы в целом) в большинстве случаев не удобны для пользователя:- Они не обеспечивают легкий доступ к контенту во фрейме через URL (по крайней мере, без потери контента за пределами фрейма).
- Большинство пользователей "технофобов" раздражены фреймами.
- Насколько я знаю, они медленнее рендерится для браузеров
- Альтернативы включают динамическое генерирование страниц (SSI, PHP, Rails и т. Д.) И использование JavaScript / AJAX для изменения содержимого, например
<div>
Чтобы было ясно: я говорю о <iframe>
в качестве элемента интерфейса. Не скрытый элемент для загрузки других вещей, таких как, например, Google Mail.
IFrames не устарели, но причины их использования редки.
- Использование IFrames для обслуживания вашего собственного контента создает "стену" вокруг доступа к контенту в этой области.
- Для сканеров, таких как Google, не сразу ясно, что cotent в iframe будет оцениваться так же высоко, как если бы контент был просто частью страницы. Для многих это является достаточной причиной, чтобы не использовать его.
- Это делает DOM для IFrame менее доступным с помощью таких инструментов, как jQuery, прототип и т. Д.
Причины использования фреймов:
- Он отлично подходит для ограждения чужих вещей от других доменов, но он не интегрируется гладко. (таблицы стилей, JavaScript и т. д.)
- Интеграция мультимедиа иногда может быть проще с помощью iframe, в отличие от использования тега embed.
- Действительно, действительно специализированные случаи, такие как случай gmail, когда они используют его для управления звуками и историей.
Я также ответил бы, что нет необходимости удалять iframes, это необходимый тег, который будет присутствовать некоторое время.
Iframes устарели для макета страницы. Никогда не используйте их вместо хорошего макета CSS, даже макет на основе таблицы лучше.
Хорошие причины для использования iframes:
- ads: adwords, например, использует эту технику, она хороша для инкапсуляции - ad css не разрушит вашу страницу.
- скрытый iframe: его можно использовать для сотен полезных вещей, таких как отслеживание, альтернатива ajax и т. д.
Я видел много форумов, которые предлагают тег Object в качестве замены для IFrame, который, вероятно, работает в большинстве случаев.
Например, у меня был PDF-файл, отображаемый в IFrame (потому что были и другие вещи, которые нам нужно показать на странице, кроме только PDF-файла), и я смог заставить его хорошо отображаться с помощью Object.
Что было:
<iframe id="confirmed_pdf" class="current_pdf" src="/prescriptions/show_pdf?id=123" height="570" width="480"></iframe>
стала:
<object id="confirmed_pdf" class="current_pdf" data="/prescriptions/show_pdf?id=123" type="application/pdf" height="570" width="480">
<p>[Show this message if displaying the PDF did not work]</p>
</object>
Но Object не был подходящей заменой для выполнения требования, чтобы иметь возможность печатать ТОЛЬКО часть PDF страницы.
IFrame похож на свое собственное окно на странице (в основном это окно внутри окна), и как только вы получите объект окна, вы можете вызвать для него.print(), например:
jQuery("#confirmed_pdf").contentWindow.print();
IFrame имеет свойство contentWindow, что делает возможным печать только этой части. У объекта нет свойства contentWindow, поэтому нет возможности распечатать только раздел страницы.
Таким образом, кажется, что если вы просто используете IFrame для отображения чего-то, есть другие теги, такие как Object, которые можно использовать вместо этого. Но если вам нужно определенным образом взаимодействовать с содержимым IFrame, тогда IFrame может оказаться необходимым.
IFrames не мертвы, но Frameset/Frames умирают.
В последних двух выпусках IE (IE7 / IE8) масштабирование кадров (не IFrames) привело к катастрофическим результатам.
Конечно, используйте IFrames, но IMHO держитесь подальше от Framesets/Frames.
IFrames часто используются с AJAX. GMail, например, использует девять скрытых IFrames, я верю.
Лошади для курсов...
В Ajax
В моей предыдущей компании мы предоставили размещаемое приложение, которое клиенты могли бы интегрировать в свои собственные веб-сайты. Иногда для этого они использовали бы IFrame, вписывая нашу размещенную страницу в свои существующие дизайны. Иногда это даже было сделано незаметно (т. Е. IFrame не имел границ или полос прокрутки, он просто выглядел как часть страницы). Я считаю, что это хорошее использование тега.
Они могут быть чрезвычайно полезны в некоторых обстоятельствах, но они ограничены. В частности, встраивание общих функций на нескольких сайтах.
Например, у меня есть клиент, который работает на нескольких сайтах электронной торговли шотландскими товарами. В рамках этого мы разработали несколько простых приложений для поиска возможных названий кланов по вашей фамилии или по вашему выбору тартанов (хихикайте, если хотите, но тартаны приносят нашей экономике 700 миллионов долларов в год). База данных за этим удивительно велика (около десяти тысяч строк в таблицах основных имен и тартанов) и довольно регулярно обновляется.
Таким образом, у нас есть приложения, настроенные для запуска на одном веб-сайте, а затем встроенные в другие наши веб-сайты с помощью iframe, позволяющие простую передачу параметров javascript, чтобы мы могли интегрировать выбор тартана или клана с функциональностью на сайте встраивания. Iframe установлен как noborder, поэтому он кажется полностью незаметным для конечного пользователя.
Конечно, есть и другие способы сделать это, но использование iframe простое и надежное. И это, конечно, не устарело.
В настоящее время спецификация гаджета Google основана на iframes: http://code.google.com/apis/gadgets/docs/spec.html
В настоящее время они являются единственным простым способом обеспечить изоляцию для приложений JavaScript, которые извлекаются из нескольких доменов / провайдеров.
Также многие из виджетов, которые люди встраивают на свои сайты от сторонних производителей, используют фреймы.
Несмотря на то, что они имеют свои недостатки, iframes обеспечивают прагматичное решение общих проблем в сети. Я должен был бы предположить, что они будут рядом в течение некоторого времени.
Вопросы соответствия и безопасности также могут побудить вас использовать Iframes; Корзины покупок - это популярные реализации на основе IFrame, когда вы хотите визуально включить корзину покупок как часть некоторых веб-страниц, не принимая на себя полную ответственность за обработку платежей.
Мы обычно поставляем Iframe для интеграции наших компонентов электронной коммерции и клиентов, например, "под ключ".
Я только что изменил сайт с обычного набора фреймов на Iframes, так как обычные фреймы не могли делать то, что мне было нужно. Это не вызвало проблем с остальной частью кода.
Я работаю в компании, которая использовала фреймы для всего: от выпадающих меню, списков, блоков контента и т. Д., Чтобы покрыть тонкости веб-форм.net. Приложение работает очень медленно и работает только в IE. Не делай этого.