Ver Mensaje Individual
  #1 (permalink)  
Antiguo 28/08/2009, 06:34
thi
 
Fecha de Ingreso: abril-2009
Mensajes: 244
Antigüedad: 15 años, 1 mes
Puntos: 0
Mejora de codigo menus popup

Hola a todos,

me he descargado un codigo para hacer menus popup y lo he adaptado un poco a mis necesidades, pero me da la impresión de que puede estar un poco obsoleto o que no me va a servir para todos los navegadores, como no tengo mucha idea de javascript me gustaría conocer vuestras opiniones sobre este codigo.

Si alguien conoce un metodo mejor para hacer menus popup estoy dispuesto a descartar este.

Codigo:

<SCRIPT LANGUAGE="JavaScript">

<!-- Begin
// ############## SIMPLE BROWSER SNIFFER
if (document.layers) {navigator.family = "nn4"}
if (document.all) {navigator.family = "ie4"}
if (window.navigator.userAgent.toLowerCase().match("g ecko"))

{navigator.family = "gecko"}

// ######### popup text
descarray = new Array(
"<div align=left><ul><li><a href=''>Ir a la

Web</a></li><li><a href=''>Ir a la

Ficha</a></li><li>Telefonos:<ul><li>999999999</li><li>696969

696</li></ul></li><li>Emails:<ul><li>[email protected]</li><li

>[email protected]</li></ul></li></ul></div>"
);

overdiv="0";
// ######### CREATES POP UP BOXES
function popLayer(a){
if(!descarray[a]){descarray[a]="<font color=red>This popup

(#"+a+") isn't setup correctly - needs description</font>";}
if (navigator.family == "gecko") {pad="0"; bord="1

bordercolor=black";}
else {pad="1"; bord="0";}
desc = "<table cellspacing=0 cellpadding="+pad+"

border="+bord+" bgcolor=000000><tr><td>\n"
+"<table cellspacing=0 cellpadding=3 border=0

width=100%><tr><td bgcolor=ffffdd><center><font size=-1>\n"
+descarray[a]
+"\n</td></tr></table>\n"
+"</td></tr></table>";
if(navigator.family =="nn4") {
document.object1.document.write(desc);
document.object1.document.close();
document.object1.left=x+15;
document.object1.top=y-5;
}
else if(navigator.family =="ie4"){
object1.innerHTML=desc;
object1.style.pixelLeft=x+15;
object1.style.pixelTop=y-5;
}
else if(navigator.family =="gecko"){
document.getElementById("object1").innerHTML=desc;
document.getElementById("object1").style.left=x+15 ;
document.getElementById("object1").style.top=y-5;
}
}
function hideLayer(){
if (overdiv == "0") {
if(navigator.family =="nn4")

{eval(document.object1.top="-500");}
else if(navigator.family

=="ie4"){object1.innerHTML="";}
else if(navigator.family =="gecko")

{document.getElementById("object1").style.top="-500";}
}
}

// ######## TRACKS MOUSE POSITION FOR POPUP PLACEMENT
var isNav = (navigator.appName.indexOf("Netscape") !=-1);
function handlerMM(e){
x = (isNav) ? e.pageX : event.clientX +

document.body.scrollLeft;
y = (isNav) ? e.pageY : event.clientY +

document.body.scrollTop;
}
if (isNav){document.captureEvents(Event.MOUSEMOVE);}
document.onmousemove = handlerMM;
// End -->
</script>

</HEAD>

<BODY>

<div id="object1" style="position:absolute;

background-color:FFFFDD;color:006699;border-color:black;bord

er-width:20; visibility:show; left:25px; top:-100px;

z-index:+1" onmouseover="overdiv=1;"

onmouseout="overdiv=0;setTimeout('hideLayer()',300 0)">
pop up description layer
</div>


<a href="#" onClick="popLayer(0)"

onMouseOut="setTimeout('hideLayer()',2000)"><img

src="images/logos/logotipo.gif"></a>