wing. Posted May 19, 2004 Share Posted May 19, 2004 made this menu with some help from my dhtml book am afraid i have some errors if its not to much to as can some one help me (it aint working in firefox or ie would like it to work on most browsers as well) tia :D <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Untitled Document</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <script language="JavaScript" type"text/javascript"> var objNavMenu = null; var prevObjNavMenu = null; var prevObjDropMenu =3; //////link styles var bgLinkColor = '#cccccc'; var bgLinkHover = '#ffffff'; var bgLinkActive = '#000000'; var LinkHover = '#000000'; var LinkActive = '#ffffff'; var isIE =null; if (navigator.appName.indexOf ('Microsoft Internet Explorer') != -1) isIE=1; function initDropMenu () { document.onclick = hide DropMenu; for (i=1; i<=numDropmenu; i++){ MenuName = 'dropMenu' + i; navName = 'navMenu' + i; objDropMenu = document.getElementbyId(menuName); objNavMenu = document.getElementById(NavName); objDropMenu.style.visibility = 'hidden'; objNavMenu.onmouseover =menuHover; objNavMenu.onmouseout =menuOut; objNavMenu.onclick = showDropMenu; } objNavMenu = null; return; } function menuHover(e) { document.onclick = null; hoverObjNavMenu = document.getElementById(this.id); if (hoverObjNavMenu !=objNavMenu) { hoverObjNavMenu.style.color=link linkHover; hoverObjNavMenu.style.backgroundColor = bgLinkHover; } } function menuOut (e) { document.onclick = hideDropMenu; outObjNavMenu = document.getElementById(this.id); if (out0bjNavMenu !=objNavMenu) { outObjNavMenu.style.color = linkColor; outObjNavMenu.style.backgroundColor = bglinkColor; } } function showDropMenu(e) { menuName = 'drop' + this.id.substring(3,this.id.length); objDropMenu = document.getElementById(menuName); if (prevObjDropMenu ==objDropMenu { hideDropMenu(); return; } if (prevObjDropMenu != null) hideDropMenu(); objNavMenu = document.getElementById(this.id); if ((prevObjNavMenu! = objNavMenu ) | | (prevObjDropMenu == null)) { objNavMenu.style.color = linkActive; objNavMenu.style.backgroundColor = bgLinkActive; } if (objDropMenu) { xPos = objNav.offsetParent.offsetLeft + objNavMenu.offsetLeft; yPOS = objNavMenu.offsetParent.offsetTop + objnavmenu.offsetheight: if (isIE) { yPos -=1; xPos -=6; } objDropMenu.style.left= xPos = 'px'; objDropMenu.style.visibility = 'visible'; prevObjDropMenu = objDropMenu; prevObjNavMenu = ObjNavMenu; } } function hide dropmenu() { document.onclick = null; if (prevObjDropMenu) { prevObjDropMenu.style.visibility = 'hidden'; prevObjDropMenu = null; prevObjNavMenu.style.color =link color; prevObjNavMenu.style.backgroundColor = bglinkColor; } objNavMenu = Null; } </script> <style type="text/css" media="screen"> <!-- body { margin: 0px; padding: opx; } #page{margin 10px; } #menuBar { color:#999999; font-size: 12px; font-family: arial, Helvetica, sans-serif; font-weight: bold; text-align: left; text-transform: capitalize; display: block; margin-bottom: 5px; position: realative; top: 0px; left: 0px; right: 0px; width: 99%; overflow: hidden; vertical-align: middle; border: solid 1px #000000; background-color: #cccccc; } .menuHeader{ color: #000000; tex-decoration: none; white-space: nowrap; curor: pointer; padding: 5px; margin: 0px; padding-right: 15px; display: inline; position: relative; border-right: 1px solid #000000; } a.menuLink{ display: block; padding: 2px 5px; border-top: 1px solid #cccccc; }a.menuLink:link{ color: #000000; text-decoration: none; } a.menuLink:visited { color: #000000; text-decoration:none } a.menuLink:hover { color: #ffffff; text-decoration: none; background-colour:#000000; } a.menuLink:active { color: #ffffff text-decoration: none; background-color: #cc0000; } .menuDrop { color: #999999; font-size: 10px; font-family: arial, Helvetica, sans-serif; background-reapeat: repeat; visibility: hidden; margin: 0; padding: 0: position: absolute; z-index: 1000; top: 60px; left: 0; width: 175px; height: auto; border-style: solid; border-width: 0 1px 1px; borrder-color:#003365 } --!> </style> </head> <body bgcolor="#ffffff" onLoad="initDropMenu()"> <div id="menuBar"> </div><div id="Navmenu1" class"menuheader">Menu 1</div> <div id="navMenu2" class="menuHeader"> menu 2</div> <div div id="navMenu3" class="menuHeader">menu 3</div> <div id="dropMenu1" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link1</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link2</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link3</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link4</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link5</a>;div id="dropMenu2" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link1</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link2</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link3</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link4</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link5</a>;div id="dropMenu3" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link1</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link2</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link3</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link4</a>t;a class="menuLink" href="#" onFocus="if(this.blur)this.blur();">link5</a>;/div> </body> </html> Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/ Share on other sites More sharing options...
0 Judge Verbose Posted May 20, 2004 Share Posted May 20, 2004 not sure exactly what you are trying to do, as my java isnt very good. but it looks like it can all be done in css. http://css.maxdesign.com.au/listamatic2/ try that, has some examples under horizontal that may help you. Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2133177 Share on other sites More sharing options...
0 wing. Posted May 21, 2004 Author Share Posted May 21, 2004 any 1 else??? :) please Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2139108 Share on other sites More sharing options...
0 TomUsher Posted May 21, 2004 Share Posted May 21, 2004 You really don't need that much code for a dropdown menu... have a look at articles like http://www.alistapart.com/articles/dropdowns/ for help making a CSS/Javascript menu. Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2139167 Share on other sites More sharing options...
0 wing. Posted May 21, 2004 Author Share Posted May 21, 2004 tbh trefaes i would really like to get this working :) Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2139354 Share on other sites More sharing options...
0 wing. Posted May 21, 2004 Author Share Posted May 21, 2004 bump :shifty: Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2139592 Share on other sites More sharing options...
0 wing. Posted May 21, 2004 Author Share Posted May 21, 2004 another bump Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2140673 Share on other sites More sharing options...
0 mimeryme Posted May 21, 2004 Share Posted May 21, 2004 wing, there are too many syntax errors. You should try to be more careful when typing this out. There were mistakes in the html, css, and javascript. I fixed it up and it's more readable now, but I couldn't get the initializing method to work. It still doesn't work in IE and still a little bit flaky in Firefox anyway. Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2140987 Share on other sites More sharing options...
0 mimeryme Posted May 21, 2004 Share Posted May 21, 2004 (edited) edit: closing divs <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Untitled Document</title> <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"> <script language="JavaScript" type="text/javascript"> <!-- var objNavMenu = null; var prevObjNavMenu = null; var prevObjDropMenu = null; var numDropMenu = 3; // link styles var bgLinkColor = '#cccccc'; var bgLinkHover = '#ffffff'; var bgLinkActive = '#000000'; var linkColor = '#ff0000'; var linkHover = '#000000'; var linkActive = '#ffffff'; var isIE = null; if (navigator.appName.indexOf ('Microsoft Internet Explorer') != -1) isIE=1; function InitDropMenu() { // document.onClick = HideDropMenu(); for (i=1; i <= numDropMenu; i++){ menuName = 'dropMenu' + i; navName = 'navMenu' + i; objDropMenu = document.getElementById(menuName); objNavMenu = document.getElementById(navName); objDropMenu.style.visibility = 'hidden'; objNavMenu.onMouseOver = MenuHover(objNavMenu); objNavMenu.onMouseOut = MenuOut(objNavMenu); objNavMenu.onClick = ShowDropMenu(objNavMenu); } objNavMenu = null; return; } function MenuHover(e) { document.onClick = null; hoverObjNavMenu = document.getElementById(e.id); if (hoverObjNavMenu != objNavMenu) { hoverObjNavMenu.style.color = linkColor; hoverObjNavMenu.style.backgroundColor = bgLinkHover; } } function MenuOut(e) { // document.onClick = HideDropMenu(); outObjNavMenu = document.getElementById(e.id); if (outObjNavMenu != objNavMenu) { outObjNavMenu.style.color = linkHover; outObjNavMenu.style.backgroundColor = bgLinkColor; } } function ShowDropMenu(e) { menuName = 'drop' + e.id.substring(3, e.id.length); objDropMenu = document.getElementById(menuName); if (prevObjDropMenu == objDropMenu) { HideDropMenu(); return; } if (prevObjDropMenu != null) { HideDropMenu(); return; } objNavMenu = document.getElementById(e.id); if ((prevObjNavMenu != objNavMenu ) || (prevObjDropMenu == null)) { objNavMenu.style.color = linkActive; objNavMenu.style.backgroundColor = bgLinkActive; } if (objDropMenu) { xPos = objNavMenu.offsetParent.offsetLeft + objNavMenu.offsetLeft; yPoS = objNavMenu.offsetParent.offsetTop + objNavMenu.offsetheight; if (isIE) { yPos -=1; xPos -=6; } objDropMenu.style.left= xPos; objDropMenu.style.visibility = 'visible'; prevObjDropMenu = objDropMenu; prevObjNavMenu = objNavMenu; } } function HideDropMenu() { document.onClick = null; if (prevObjDropMenu) { prevObjDropMenu.style.visibility = 'hidden'; prevObjNavMenu.style.color = linkColor; prevObjNavMenu.style.backgroundColor = bgLinkColor; prevObjDropMenu = null; } // objNavMenu = null; } // --> </script> <style type="text/css" media="screen"> body { margin: 0px; padding: opx; } #page{ margin 10px; } #menuBar { color:#999999; font-size: 12px; font-family: arial, Helvetica, sans-serif; font-weight: bold; text-align: left; text-transform: capitalize; display: block; margin-bottom: 5px; position: realative; top: 0px; left: 0px; right: 0px; width: 99%; overflow: hidden; vertical-align: middle; border: solid 1px #000000; background-color: #cccccc; } .menuHeader{ color: #000000; text-decoration: none; white-space: nowrap; cursor: pointer; padding: 5px; margin: 0px; padding-right: 15px; display: inline; position: relative; border-right: 1px solid #000000; } a.menuLink{ display: block; padding: 2px 5px; border-top: 1px solid #cccccc; } a.menuLink:link{ color: #000000; text-decoration: none; } a.menuLink:visited { color: #000000; text-decoration:none } a.menuLink:hover { color: #ffffff; text-decoration: none; background-color:#000000; } a.menuLink:active { color: #ffffff text-decoration: none; background-color: #cc0000; } .menuDrop { color: #999999; font-size: 10px; font-family: arial, Helvetica, sans-serif; background-reapeat: repeat; visibility: hidden; margin: 0; padding: 0: position: absolute; z-index: 1000; top: 60px; left: 0; width: 175px; height: auto; border-style: solid; border-width: 0 1px 1px; border-color:#003365 } </style> </head> <body bgcolor="#ffffff" onLoad=""> <div id="menuBar"> <div id="navMenu1" class="menuheader" onClick="ShowDropMenu(this);" onMouseOver="MenuHover(this);" onMouseOut="MenuOut(this);">Menu 1</div> <div id="navMenu2" class="menuHeader" onClick="ShowDropMenu(this);" onMouseOver="MenuHover(this);" onMouseOut="MenuOut(this);">menu 2</div> <div id="navMenu3" class="menuHeader" onClick="ShowDropMenu(this);" onMouseOver="MenuHover(this);" onMouseOut="MenuOut(this);">menu 3</div> </div> <div id="dropMenu1" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link1</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link2</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link3</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link4</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link5</a></div> <div id="dropMenu2" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link6</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link7</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link8</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link9</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link10</a></div> <div id="dropMenu3" class="menuDrop"> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link11</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link12</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link13</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link14</a> <a class="menuLink" href="#" onFocus="if(this.blur)this.blur();" onClick="HideDropMenu();">link15</a> </div> </body> </html> Edited May 21, 2004 by mimeryme Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2141001 Share on other sites More sharing options...
0 TomUsher Posted May 21, 2004 Share Posted May 21, 2004 And those divs at the bottom aren't closed :) Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2141043 Share on other sites More sharing options...
0 wing. Posted May 21, 2004 Author Share Posted May 21, 2004 thanks alot mimeryme !!!! Link to comment https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/#findComment-2141108 Share on other sites More sharing options...
Question
wing.
made this menu with some help from my dhtml book am afraid i have some errors if its not to much to as can some one help me (it aint working in firefox or ie would like it to work on most browsers as well)
tia :D
Link to comment
https://www.neowin.net/forum/topic/168855-help-fixing-dhtml-css-menu/Share on other sites
10 answers to this question
Recommended Posts