Todas las entradas recientemente escritas, así como las antigüas-tanto de "AyudaKaos, como las de este blog (Aire(bis)- están reunidas en Epílogo. porque... resulta más fácil encontrarlo todo en el mismo lugar...


2 comentarios

Switch Menú


Como decía otro día, lo ví en Dynamicdrive: Hacía mucho que deseaba algo así para mi blog... y sólo encontraba cosas que funcionaban... para Firefox.



Y es tan sencillo como mantener la unidad de ID a la hora de diseñar su contenido. Y sólo dos pasos:

1º.- CSS (antes del cierre /skin... al menos a mí me gusta poner ahí los CSS... aunque hay gente que los coloca inmediatamente antes del cierre /head... cada quien a lo suyo: yo prefiero en "exclusiva" el /head para los scripts):




<style type="text/css">

.menutitle{

cursor:pointer;

margin-bottom: 5px;

background-color:#ECECFF;

color:#000000;

width:140px;

padding:2px;

text-align:center;

font-weight:bold;

/*/*/border:1px solid #000000;/* */

}



.submenu{

margin-bottom: 0.5em;

}

</style>



<script type="text/javascript">



/***********************************************

* Switch Menu script- by Martial B of http://getElementById.com/

* Modified by Dynamic Drive for format & NS4/IE4 compatibility

* Visit http://www.dynamicdrive.com/ for full source code

***********************************************/



var persistmenu="yes" //"yes" or "no". Make sure each SPAN content contains an incrementing ID starting at 1 (id="sub1", id="sub2", etc)

var persisttype="sitewide" //enter "sitewide" for menu to persist across site, "local" for this page only



if (document.getElementById){ //DynamicDrive.com change

document.write('<style type="text/css">\n')

document.write('.submenu{display: none;}\n')

document.write('</style>\n')

}



function SwitchMenu(obj){

if(document.getElementById){

var el = document.getElementById(obj);

var ar = document.getElementById("masterdiv").getElementsByTagName("span"); //DynamicDrive.com change

if(el.style.display != "block"){ //DynamicDrive.com change

for (var i=0; i<ar.length; i++){

if (ar[i].className=="submenu") //DynamicDrive.com change

ar[i].style.display = "none";

}

el.style.display = "block";

}else{

el.style.display = "none";

}

}

}



function get_cookie(Name) {

var search = Name + "="

var returnvalue = "";

if (document.cookie.length > 0) {

offset = document.cookie.indexOf(search)

if (offset != -1) {

offset += search.length

end = document.cookie.indexOf(";", offset);

if (end == -1) end = document.cookie.length;

returnvalue=unescape(document.cookie.substring(offset, end))

}

}

return returnvalue;

}



function onloadfunction(){

if (persistmenu=="yes"){

var cookiename=(persisttype=="sitewide")? "switchmenu" : window.location.pathname

var cookievalue=get_cookie(cookiename)

if (cookievalue!="")

document.getElementById(cookievalue).style.display="block"

}

}



function savemenustate(){

var inc=1, blockid=""

while (document.getElementById("sub"+inc)){

if (document.getElementById("sub"+inc).style.display=="block"){

blockid="sub"+inc

break

}

inc++

}

var cookiename=(persisttype=="sitewide")? "switchmenu" : window.location.pathname

var cookievalue=(persisttype=="sitewide")? blockid+";path=/" : blockid

document.cookie=cookiename+"="+cookievalue

}



if (window.addEventListener)

window.addEventListener("load", onloadfunction, false)

else if (window.attachEvent)

window.attachEvent("onload", onloadfunction)

else if (document.getElementById)

window.onload=onloadfunction



if (persistmenu=="yes" && document.getElementById)

window.onunload=savemenustate



</script>





2º.- HTML: A insertar en el cuerpo de la plantilla (body) donde cada quien desee. Se puede insertar directamente en Edición de Plantilla o en Diseño-Añadir Elemento HTML-JAVA:




<!-- Keep all menus within masterdiv-->

<div id="masterdiv">



<div class="menutitle" onclick="SwitchMenu('sub1')">Site Menu</div>

<span class="submenu" id="sub1">

- <a href="new.htm">What's New</a><br>

- <a href="hot.htm">What's hot</a><br>

- <a href="revised.htm">Revised Scripts</a><br>

- <a href="morezone/">More Zone</a>

</span>



<div class="menutitle" onclick="SwitchMenu('sub2')">FAQ/Help</div>

<span class="submenu" id="sub2">

- <a href="notice.htm">Usage Terms</a><br>

- <a href="faqs.htm">DHTML FAQs</a><br>

- <a href="help.htm">Scripts FAQs</a>

</span>



<div class="menutitle" onclick="SwitchMenu('sub3')">Help Forum</div>

<span class="submenu" id="sub3">

- <a href="http://www.codingforums.com">Coding Forums</a><br>

</span>



<div class="menutitle" onclick="SwitchMenu('sub4')">Cool Links</div>

<span class="submenu" id="sub4">

- <a href="http://www.javascriptkit.com">JavaScript Kit</a><br>

- <a href="http://www.freewarejava.com">Freewarejava</a><br>

- <a href="http://www.cooltext.com">Cool Text</a><br>

- <a href="http://www.google.com">Google.com</a>

</span>



<img src="about.gif" onclick="SwitchMenu('sub5')"><br>

<span class="submenu" id="sub5">

- <a href="http://www.dynamicdrive.com/link.htm">Link to DD</a><br>

- <a href="http://www.dynamicdrive.com/recommendit/">Recommend Us</a><br>

- <a href="http://www.dynamicdrive.com/contact.htm">Email Us</a><br>

</span>



</div>





Y acordaos de subir el botón del "About"... o no "funcionará".
Para insertar más elementos en el desplegable... repetid la tag de cierre y apertura de "a", terminado con el "span" el último elemento que insertéis.
Para añadir más menús, copiad la estructura del menú y submenú y cambiad el número por el orden que haga, p.e.: si el hack tiene "5" menús, el nuevo a insertar será el "6"... y ojo, que tambíén hay que cambiar el número en el submenú.

2 comentarios

melanista dijo...

Hola! Estaba intentando usar este hack pero no entiendo la parte final donde dices: "acordaos de subir el botón del "About"... o no "funcionará"
¿Podrías explicarme a qué te refieres?
Saludos!

Pilar Lozano Santos dijo...

Hola efecinco:

Sí, mira: el botón del "About" es el que, al pincharlo, despliega la información de tu perfil.

Pero el botón es una imagen... si no subes la imagen a tu ordenador, no te saldrá. Así que tienes que pinchar en la imagen con el botón derecho del ratón y "guardar como": así lo guardas en el archivo que quieras de tu pc., p.e., "imágenes". De esta forma, ya puedes hallar la URL "src=" de tu botón-About para insertarla en el hack y hacer que se vea la imagen.

Cuando dije "no funcionará", me refería a que no veríais la imagen del botón si no la guardáis en vuestro pc.

Espero haberme explicado mejor y... ¡suerte con el hack!. Que te salga bien :)