5
votes

When the main Window wants to send message to a child Iframe -

It sets the child's Iframe url to its current url+ hash (which represents data).

But how would the iframe get's the new data ?

We have 4 options : ( i'm not talking about new api's eg postMessaage nor XDM libraries)

  • The child is polling the new hash ( setTimeout)

  • The main window can resize the iframe (the iframe must register onResize)

  • The OnHashChange Event can be used on the iframe

  • Destroying/creating proxy Iframe which uses "onload" to send msg (javascript function !) to its "SameDomainIframe" via parent.frames['samedonain'].sendData(...)

Here comes my question : (regarding option#2 ( resize event) ):

According to this article :

In Firefox, Opera, Google Chrome and Safari, the onresize event is fired only when the size of the browser window is changed. In Internet Explorer, the onresize event is fired when the size of the browser window or an element is changed.

Question :

Is there any cross browser solution for this resize thing ?

I don't want a situation where a user resize the browser , and the iframe will re-read the data !

I want the data to be read Only when I send a message to the iframe and manually resize it

1
“We have 2 options” – we also have option 3CBroe
@CBroe Totally agree.Royi Namir
@CBroe There is another one./edited.Royi Namir
So why are you so focused on the resize method?CBroe
@CBroe Cuz it's much simpler than dealing with another proxy iframe , and OnHashChange is IE8+. Also polling is the worst solution ever. and I want to know this topic with all its aspects. I like this cross domain topic very much. it all started when i read this article which uses the onresize.Royi Namir

1 Answers

2
votes

You can use porthole which is a cross browser proxy script for iframes you will need to be able to host a small proxy file on the receiving end of the other iframe though. You can then pass information and events from one iframe to another across browsers and domains

http://ternarylabs.github.io/porthole/