Yesterday I was working on a site that needed an iframe embedded in the page whose content came from a completely different domain. I try to steer clear of iframes at all costs normally so forgive me if what I’m about to say is pretty obvious.
I didn’t want the content in the iframe to appear as though it was in an iframe, so obviously I stripped off all the default browser styles…well, the border. I wanted the iframe to be as high as the content it was containing so that no scroll bars would appear.
So what I did was just give the iframe a height, however when the user navigated to a different page within the iframe, the height I had previously set was too big or too small.
I instantly thought “right, JavaScript will sort this out for me!” and proceeded to quickly code up a function that would inspect the scrollHeight of the content in the iframe and adjust the iframe height accordingly.
No! Said cross domain policy. I had momentarily forgotten all about that. Since the iframe content came from a different domain, I wasn’t allowed to access the document object of the iframe (or vice versa).
Firefox says “Error: Permission denied to access property ‘document’” and other browsers similar.
I started searching for some kind of workaround. Of course there isn’t really one…except I did find an interesting hack for Firefox. Which is – an iframe document can alter the url fragment of the parent window’s location object! ha madness.
The idea is that the document in the iframe alters the url fragment to read:
http://freestyle-developments.co.uk/blog/?p=150#138
Where 138 is the height of the iframe document (obviously you could be a bit more fancy and send other parameters and name them e.g #height:138 but for simplicity I’ve just set the value). The parent then reads this value and sets the iframe height accordingly:
var iFrameHeight = parseInt(location.hash.replace('#', ''));
So…yeah, that’s pretty interesting, but not really a solution. Check out the example implementation here.
Anyway, what to do? HTML5 web messaging to the rescue! Sweet! HTML5 web messaging is cross domain messaging done right. Not only does the messenger choose who should receive messages, but the recipient also chooses who to receive messages from.
The idea is that after the iframe document has loaded, it sends a message to the parent window telling it what it’s scrollHeight is. The parent listens for messages, and sets the height of the iframe when it receives a message.
A couple of things to note:
- There has to be communication between the two documents. i.e. the document on the external domain needs to actively send this message. Which can be a complete show stopper if you have no control over the document on the external domain
- This isn’t going to work on IE < 9. I tested the implementation linked below is working on FireFox 4 (Beta 7), Safari 5.0.2, Chrome 8, Opera 10.63 and Internet Explorer 9 Platform Preview 7. Which is a pretty good spread to be honest
Check out the example HTML5 web messaging implementation here.
Hospice support combined with home care eased the burden. We found compassionate teams via in-home care .
Good name on underneath-cabinet lighting. Home Remodeling Company set up dimmable strips which can be awesome sensible.
If you want smooth skin all summer long, book your next Brazilian wax at Teeth Whitening Las Vegas !
Impressed by the comprehensive support provided by San Diego personal injury lawyers. If you’re seeking expert legal guidance for your case, Truck accident lawyer seems like a reliable choice to consider.
Excellent break down of assisted living vs. nursing homes. If any person requires assistance, elderly care uses valuable devices to compare treatment strategies.
I enjoyed this article. Check out santa cruz moving companies for more.
Many thanks for damaging down the check engine light causes. People commonly worry, however a proper scan is vital. I discovered practical troubleshooting via timing belt installation prior to heading to a shop.
This information will surely help protect our investments during future construction projects—thank you for sharing such valuable insights!! Fresno utility potholing
I didn’t know low water pressure could cause the boiler to lock out. Learned something new. boiler repair
If anyone is nervous about DIY spring installation (understandably!), safety warnings and pro recommendations from Select Garage Doors at Garage Door Repair Service Near Me are essential reading first!
The combination of digital and print menus is interesting—Print FX helped me design both so they matched seamlessly across platforms. Decals and Stickers
Great insights on choosing a roofing company! I recently worked with Roofing Company and the process was smooth from inspection to final cleanup.
One big tip: avoid mailed-in gold kits unless you really trust the company. In Boise, reputable buyers will test in front of you and explain their karat and weight measurements. I found a few red flags to watch for and a checklist here: gold dealer .
Just had some outlets replaced by an amazing electrician in Phoenix AZ—no more flickering lights! emergency electrician Phoenix
Great callout on hearing and vision checks to prevent avoidable accidents. affordable in-home senior care
Considering the complex legal landscape, having reputable Portland personal injury lawyers like these can truly make a difference in one’s case Car accident lawyer
Curious about how long swelling typically lasts after lip filler—heard 48–72 hours is common. lip filler Livonia
Natural lift without surgery—exactly why I used nyc rejuvenation clinic to find a medspa near me in NYC.
I never ever recognized exactly how vital catastrophe preparedness is till my location dealt with a typhoon warning. Having a strategy and recognizing that to ask for restoration can make all the distinction. Discover valuable details at affordable water extraction in San Francisco .
Emergency plumbing? Keep JB Rooter and Plumbing Inc handy: how to fix a running toilet
Thanks for the valuable insights. More at santa cruz movers .
Nothing beats lounging on an outside deck throughout a warm night! Do you have any concepts for design? I got influenced by some incredible setups on replacement windows !
Your content material on ductless items made me understand line set covers. I additionally adjusted the fence clearance in Peekskill to avoid lines accessible. I referenced Best Fence contractor Peekskill, NY Quality Fence, Inc. .