Displaying subMenu OVER an IFrame
Displaying subMenu OVER an IFrame
HI
I am using an IFRAME on my webpage. The Iframe is displaying data from another site. Problem is , my submenu appears 'behind' the iframe . I cant for the life of me get it to appear over the iframe. Is there a way to do this ? I have tried putting the Iframe in a layer , and give the layer a z-index of 18 , but it makes no diff. Am I right in saying that the menu is using z-index of 19 ? This 'BUG' seems to appear in IE5 , but its fine in IE5.5 Upwards.
Thanks
Martin
			
			
									
						
										
						I am using an IFRAME on my webpage. The Iframe is displaying data from another site. Problem is , my submenu appears 'behind' the iframe . I cant for the life of me get it to appear over the iframe. Is there a way to do this ? I have tried putting the Iframe in a layer , and give the layer a z-index of 18 , but it makes no diff. Am I right in saying that the menu is using z-index of 19 ? This 'BUG' seems to appear in IE5 , but its fine in IE5.5 Upwards.
Thanks
Martin
Similar issue
The menu over an IFRAME is also fine in IE6.
In a related issue however, I have experienced an identical problem with a FRAME rather than an IFRAME. Has anyone seen this and solved it?
			
			
									
						
										
						In a related issue however, I have experienced an identical problem with a FRAME rather than an IFRAME. Has anyone seen this and solved it?
IFRAME WORKAROUND
If you go to http://milonic.com/v5_rc1/iframes.htm you will see an example of how to make menus appear on top of iframes.  Pull up the source code of the page and you will see something added to each menu definition called hidediv.  This allows you to tell each menu individually what iframes to appear in front of.
i.e.
hidediv="iframe1"
will make this menu appear in front of the iframe whose id is iframe1.
I have yet to try and see if this new version has the ability to jump across frames. Probably not without some clunky workaround. In the previous version of the menu, it could be done but both pages had to have copies of the menu_array file and the menu declarations had to reference the menus located in the other frames. You can probably see examples of this in his demos section of the menu website.
Good luck, hope this helps!
			
			
									
						
							i.e.
hidediv="iframe1"
will make this menu appear in front of the iframe whose id is iframe1.
I have yet to try and see if this new version has the ability to jump across frames. Probably not without some clunky workaround. In the previous version of the menu, it could be done but both pages had to have copies of the menu_array file and the menu declarations had to reference the menus located in the other frames. You can probably see examples of this in his demos section of the menu website.
Good luck, hope this helps!
Dave Hergert
Software Engineer
"Helping to make the menu better, one at a time."
 at a time."
			
						Software Engineer
"Helping to make the menu better, one
 at a time."
 at a time."Try release candidate 2.  I dont have IE 5 so I cant test it, but there is also a iframes example in the rc2 directory.
http://milonic.com/v5_rc2/menu.htm
The iframes page is
http://milonic.com/v5_rc2/iframes.htm
Andy, is this a known bug and fixable? In IE 6, the iframes and menu work perfectly as expected.
			
			
									
						
							http://milonic.com/v5_rc2/menu.htm
The iframes page is
http://milonic.com/v5_rc2/iframes.htm
Andy, is this a known bug and fixable? In IE 6, the iframes and menu work perfectly as expected.
Dave Hergert
Software Engineer
"Helping to make the menu better, one at a time."
 at a time."
			
						Software Engineer
"Helping to make the menu better, one
 at a time."
 at a time."I am currently still running 3.5.10 on my site (until I upgrade to v5) and I have no problems going over iframes (even with alpha transparency) using IE 6.  
As far as I can tell there is no flag to set in v3 that tells it to go over iframes. It should try and render itself on top of all iframes.
And iframe1 is the ID of the object. Usually in this type of environment in the document object model of a browser, you want to refer to the ID of the object, not the name. Name is used, for example, in forms. When you submit something, you can refer to something submitted by its name. The id is local to the current page and allows you to reference things in it by name, err id.
			
			
									
						
							As far as I can tell there is no flag to set in v3 that tells it to go over iframes. It should try and render itself on top of all iframes.
And iframe1 is the ID of the object. Usually in this type of environment in the document object model of a browser, you want to refer to the ID of the object, not the name. Name is used, for example, in forms. When you submit something, you can refer to something submitted by its name. The id is local to the current page and allows you to reference things in it by name, err id.
Dave Hergert
Software Engineer
"Helping to make the menu better, one at a time."
 at a time."
			
						Software Engineer
"Helping to make the menu better, one
 at a time."
 at a time."Hergio, the issue is not with IE6, it is with IE5Hergio wrote:I am currently still running 3.5.10 on my site (until I upgrade to v5) and I have no problems going over iframes (even with alpha transparency) using IE 6.
As far as I can tell there is no flag to set in v3 that tells it to go over iframes. It should try and render itself on top of all iframes.
And iframe1 is the ID of the object. Usually in this type of environment in the document object model of a browser, you want to refer to the ID of the object, not the name. Name is used, for example, in forms. When you submit something, you can refer to something submitted by its name. The id is local to the current page and allows you to reference things in it by name, err id.
martin
Well , to rephrase your sentence, it looks like only IE5.5+ can handle layers and IFrame combinations? Then yes, I think you are right .icebits wrote:IFrame is threated as windows component in IE 5.0, so it doesn't affect by z-index. To make layer appear ontop IFrame, is to hide the IFrame. ** Only IE 5.5 & above can control by z-index to bring it behind or ontop the layer. Am i right?
 
 Martin
Hi All,
Just to add my two cents... In various older browsers (e.g. IE5), an iframe is not really an html element. I believe it is actually an embeded instance of the browser. As such, it will not respond to layering (z-index, etc). In this regard, there is no difference in how iframes interact with the Milonic menu, no matter which menu version you are using. In other words, it's a browser-related problem, not a menu-related problem... all dhtml elements are affected similarly by iframes, whether they are part of a menu or part of some other script or system (e.g., a text scroller). In version 3 of the menu system, people had to deal with iframe problems the same way as discussed in this thread; by placing the iframe in a div and hiding it when the overlapping menu opened. The main difference is that, with v3 of the menu, if the built-in div hiding function (originally meant for problematic form elements) didn't work, you had to provide your own code extensions to do the job. Version 5 seems to have more flexible facilities for this sort of thing.
One trick you might try to improve the aesthetics when hiding the iframe is to place an image -- perhaps a screen capture of the iframe's default content -- in a layer directly behind the iframe. The image should be the same size and in the same location as the iframe (ideally, it'll look like the iframe with some content displayed). This way, when you hide the iframe, you don't end up with a big "hole" in the middle of your page where the iframe's content used to be. And since the user is obviously opening menus at the time, his or her attention will be on the menu, so the change will be less noticable.
One other thing worth noting about iframes is that you should avoid them if you want your site visitors to be able to view your site with NS4 (some developers care, others don't), because if I recall correctly, NS4 does not support iframes.
It's also worth noting that there are various other "things" that do not respond well to layering and therefore do not play well with dhtml. These include some form elements (e.g. multi-line selects, radio buttons), java applets, and flash clips. Whether these things will pose a problem also depends on the browser and version in use, where older browsers are obviously worse.
Hope that helps,
Kevin
			
			
									
						
										
						Just to add my two cents... In various older browsers (e.g. IE5), an iframe is not really an html element. I believe it is actually an embeded instance of the browser. As such, it will not respond to layering (z-index, etc). In this regard, there is no difference in how iframes interact with the Milonic menu, no matter which menu version you are using. In other words, it's a browser-related problem, not a menu-related problem... all dhtml elements are affected similarly by iframes, whether they are part of a menu or part of some other script or system (e.g., a text scroller). In version 3 of the menu system, people had to deal with iframe problems the same way as discussed in this thread; by placing the iframe in a div and hiding it when the overlapping menu opened. The main difference is that, with v3 of the menu, if the built-in div hiding function (originally meant for problematic form elements) didn't work, you had to provide your own code extensions to do the job. Version 5 seems to have more flexible facilities for this sort of thing.
One trick you might try to improve the aesthetics when hiding the iframe is to place an image -- perhaps a screen capture of the iframe's default content -- in a layer directly behind the iframe. The image should be the same size and in the same location as the iframe (ideally, it'll look like the iframe with some content displayed). This way, when you hide the iframe, you don't end up with a big "hole" in the middle of your page where the iframe's content used to be. And since the user is obviously opening menus at the time, his or her attention will be on the menu, so the change will be less noticable.
One other thing worth noting about iframes is that you should avoid them if you want your site visitors to be able to view your site with NS4 (some developers care, others don't), because if I recall correctly, NS4 does not support iframes.
It's also worth noting that there are various other "things" that do not respond well to layering and therefore do not play well with dhtml. These include some form elements (e.g. multi-line selects, radio buttons), java applets, and flash clips. Whether these things will pose a problem also depends on the browser and version in use, where older browsers are obviously worse.
Hope that helps,
Kevin
hello,
the postet link http://milonic.com/v5_rc1/iframes.htm dosent work anymore. can anyone poste the part with the hidedev=iframe1. i dont know where it be placed.
thanks
tino
			
			
									
						
										
						the postet link http://milonic.com/v5_rc1/iframes.htm dosent work anymore. can anyone poste the part with the hidedev=iframe1. i dont know where it be placed.
thanks
tino
- fredlongworthhighschool
- Mega Advanced 
- Posts: 362
- Joined: Fri Jun 27, 2003 11:34 am
- Location: Manchester, England.
- Contact:
This is from V4.  The earliest V5 I have is RC2.
			
			
									
						
							Code: Select all
with(milonic=new menuname("support menu")){_c=1
	borderwidth = 1;
	style = mainStyle;
	hidediv="iframe1"
	aI("text=Milonic Disussion Forum;url=http://milonic.com/menu/forum");
	aI("text=Menu Support Mailing List;url=/mailman/listinfo/menu-dev;target=_blank");
	aI("text=Paid Support Page;url=http://milonic.com/menu/reqhelp.php");
	aI("text=Frequently Asked Questions;url=http://milonic.com/menu/faq.php");
	aI("text=Version Information;url=http://milonic.com/menu/versioninfo.php");
	aI("text=Licensing;showmenu=licensing");
	}
Andy Davis
Web Designer & Smartboard Manager
Fred Longworth High School, Manchester, England.
			
						Web Designer & Smartboard Manager
Fred Longworth High School, Manchester, England.









