Общение между окнами и фреймами
Материал на этой странице устарел, поэтому скрыт из оглавления сайта.
Более новая информация по этой теме находится на странице https://learn.javascript.ru/cross-window-communication.
Элемент iframe является обычным узлом DOM, как и любой другой. Существенное отличие – в том, что с ним связан объект window внутреннего окна. Он доступен по ссылке iframe.contentWindow .
Таким образом, iframe.contentWindow.document будет внутренним документом, iframe.contentWindow.document.body – его и так далее.
В старых браузерах использовались другие свойства, такие как iframe.contentDocument и даже iframe.document , но они давно не нужны.
Переход внутрь ифрейма
В примере ниже JavaScript получает документ внутри ифрейма и модифицирует его:
var iframe = document.getElementsByTagName('iframe')[0]; var iframeDoc = iframe.contentWindow.document; if (iframeDoc.readyState == 'complete') < iframeDoc.body.style.backgroundColor = 'green'; >iframe.onload = function()
Атрибут src может использовать протокол javascript , как указано выше: src=»javascript:код» . При этом код выполняется и его результат будет содержимым ифрейма. Этот способ описан в стандарте и поддерживается всеми браузерами.
Атрибут src является обязательным, и его отсутствие может привести к проблемам, вплоть до игнорирования ифрейма браузером. Чтобы ничего не загружать в ифрейм, можно указать пустую строку: src=»javascript:»» или специальную страницу: src=»about:blank» .
В некоторых браузерах (Chrome) пример выше покажет iframe зелёным. А в некоторых (Firefox) – оранжевым.
Дело в том, что, когда iframe только создан, документ в нём обычно ещё не загружен.
При обычных значениях iframe src=»https://learn.javascript.ru/» , которые указывают на HTML-страницу (даже если она уже в кеше), это всегда так. Документ, который в iframe на момент срабатывания скрипта iframeDoc – временный, он будет заменён на новый очень скоро. И работать надо уже с новым документом iframeDoc2 – например, по событию iframe.onload .
В случае с javascript -протоколом, по идее, ифрейм уже загружен, и тогда onload у него уже не будет. Но здесь мнения браузеров расходятся, некоторые (Firefox) всё равно «подгрузят» документ позже. Поэтому факт «готовности» документа в скрипте проверяется через iframeDoc.readyState .
Ещё раз заметим, что при обычных URL в качестве src нужно работать не с начальным документом, а с тем, который появится позже.
Кросс-доменность: ограничение доступа к окну
Элемент является «двуличным». С одной стороны, это обычный узел DOM, с другой – внутри находится окно, которое может иметь совершенно другой URL, содержать независимый документ из другого источника.
Внешний документ имеет полный доступ к как к DOM-узлу. А вот к окну – если они с одного источника.
Это приводит к забавным последствиям. Например, чтобы узнать об окончании загрузки , мы можем повесить обработчик iframe.onload . По сути, это то же самое что iframe.contentWindow.onload , но его мы можем поставить лишь в случае, если окно с того же источника.
Если бы в примере выше был с текущего сайта, то оба обработчика сработали бы.
Иерархия window.frames
Альтернативный способ доступа к окну ифрейма – это получить его из коллекции window.frames .
Обратим внимание: в коллекции хранится именно окно ( contentWindow ), а не DOM-элемент.
Демонстрация всех способов доступа к окну:
Внутри ифрейма могут быть свои вложенные ифреймы. Всё это вместе образует иерархию.
Ссылки для навигации по ней:
- window.frames – коллекция «детей» (вложенных ифреймов)
- window.parent – содержит ссылку на родительское окно, позволяет обратиться к нему из ифрейма. Всегда верно:
// (из окна со фреймом) window.frames[0].parent === window; // true
window.frames[0].frames[0].frames[0].top === window
Свойство top позволяет легко проверить, во фрейме ли находится текущий документ:
Песочница sandbox
Атрибут sandbox позволяет построить «песочницу» вокруг ифрейма, запретив ему выполнять ряд действий.
- Заставляет браузер считать ифрейм загруженным с другого источника, так что он и внешнее окно больше не могут обращаться к переменным друг друга.
- Отключает формы и скрипты в ифрейме.
- Запрещает менять parent.location из ифрейма.
Пример ниже загружает в документ с JavaScript и формой. Ни то ни другое не сработает:
How to get the body’s content of an iframe in JavaScript?
We use getIframeContent(frameId), to get the object reference of an iframe in JavaScript.
To get the element in an iframe, first we need access the element inside the JavaScript using the document.getElementById() method by passing iframe id as an argument.
Using iframetag
The tag in HTML specifies an inline frame. This inline frame is used to embed another document within the current HTML document.
The element is supported in every browser like (Google Chrome, Microsoft edge/ internet explorer, Firefox, safari, and opera).
We are using srcdoc attribute in tag to specify the HTML content of the page to show in the .
The attribute srcdoc will take HTML_code as a value and specifies the HTML content of the page to show in the .
Following are the examples where we used the tag with srcdoc attribute to specify the HTML content of the page to show in the in HTML.
Now let’s look into the examples one by one.
Example
Following is the example program to create a window using iframe.
!DOCTYPE html> html> head> meta charset="UTF-8"> meta http-equiv="X-UA-Compatible" content="IE=edge"> meta name="viewport" content="width=device-width, initial-scale=1.0"> /head> body> iframe id = "myId" name = " myId ">. /iframe> script> var myDoc; if (window.frames && window.frames. myId && (myDoc = window.frames. myId.document)) var iframeBody = myDoc.body; var content = iframeBody.innerHTML; > /script> /body> /html>
Example
Following is the example program to place a content on the window created by iframe.
!DOCTYPE html> html> head> meta charset="UTF-8"> meta http-equiv="X-UA-Compatible" content="IE=edge"> meta name="viewport" content="width=device-width, initial-scale=1.0"> title> How to get HTML content of an iFrame using javascript? /title> /head> body> iframe id="frameID" src="Untitled-2.html"> /iframe> a href="#" onclick= "getIframeContent('frameID');"> Get content of Iframe /a> script> function getIframeContent(frameID) var frameObj = document.getElementById(frameID); var frameContent = frameObj.contentWindow.document.body.innerHTML; alert("frame content : " + frameContent); > /script> /body> /html>
Undefined.html
!DOCTYPE html> html> body> got the body's content of an iframe in JavaScript /body> /html>
After clicking on the get content a pop-up window will show the content of the iframe.