Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Accessing Elements Inside iframe and body Tags with JavaScript

I'm writing a GreaseMonkey script that modifies an attribute of an element with a specific ID, but I'm having some problems accessing it due to a nontraditional HTML hierarchy. Here's the relevant HTML:

<body>
...
    <iframe id="iframeID">
        <html>
        ...
            <body id="bodyID" attribute="value">
            ...
            </body>
        ...
        </html>
    </iframe>
...
</body> 

Where attribute is the attribute that I'm attempting to modify.

At first, not realizing I was working with an iframe and a nested body tag, I tried this:

document.getElementById('bodyID').setAttribute("attribute","value")

While this worked fine in Firefox, Chrome tells me that I can't set the attribute of null, suggesting that it cannot find any elements with the id bodyID. How can I modify this attribute in a cross-browser friendly fashion?

like image 335
Sonic42 Avatar asked Dec 27 '22 22:12

Sonic42


1 Answers

You first need to pull the document of the <iframe>:

document.getElementById('iframeID').contentDocument
.getElementById('bodyID').setAttribute("attribute","value");

Live DEMO

BTW, if you want to get the <body> node, you don't need to give id or something like that, simply:

document.body

In your case, it's the document of the <iframe>:

document.getElementById('iframeID').contentDocument.body.setAttribute("attribute","value");

A lot simpler... Isn't it?

like image 61
gdoron is supporting Monica Avatar answered Dec 31 '22 15:12

gdoron is supporting Monica