Foros del Web » Creando para Internet » CSS »

menu de despliegue

Estas en el tema de menu de despliegue en el foro de CSS en Foros del Web. hola bueno si se hacer un menu de despliegue pero quiero saber como puedo hacer que para que se abra aya que darle clik y ...
  #1 (permalink)  
Antiguo 21/09/2011, 16:42
Avatar de xlos_mas_pro  
Fecha de Ingreso: mayo-2011
Ubicación: Santiago
Mensajes: 359
Antigüedad: 13 años, 6 meses
Puntos: 11
Pregunta menu de despliegue

hola bueno si se hacer un menu de despliegue pero quiero saber como puedo hacer que para que se abra aya que darle clik y para cerrarce tambien
  #2 (permalink)  
Antiguo 21/09/2011, 17:47
Avatar de cristian_cena
Colaborador
 
Fecha de Ingreso: junio-2009
Mensajes: 2.244
Antigüedad: 15 años, 5 meses
Puntos: 269
Respuesta: menu de despliegue

El evento "onclick" no puede capturarse con css (salvo algunos trucos que podrás encontrar en araudi.net). Podrías usar un interruptor, en jquery (librería javascript) hay un método que te puede ser útil: toggle();
Aquí un ejemplo simple ;)

Saludos.
  #3 (permalink)  
Antiguo 22/09/2011, 08:18
Avatar de IsaBelM
Colaborador
 
Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 5 meses
Puntos: 1012
Respuesta: menu de despliegue

yo, antes de usar un librería, probaría con
Cita:
function fnc(cual) {
obj = document.getElementById(cual);
obj.style.display = (obj.style.display == 'none') ? 'block' : 'none';
}
  #4 (permalink)  
Antiguo 22/09/2011, 09:55
Avatar de cristian_cena
Colaborador
 
Fecha de Ingreso: junio-2009
Mensajes: 2.244
Antigüedad: 15 años, 5 meses
Puntos: 269
Respuesta: menu de despliegue

Adaptando al ejemplo anterior tendrías que:

Código HTML:
Ver original
  1. <ul>
  2.     <li class="top">
  3.         <a href="#" id="item">item 1</a>
  4.         <ul id="cont">
  5.             <li><span>item 1.1</span></li>
  6.             <li><span>item 1.2</span></li>
  7.         </ul>
  8.     </li>
  9.     <li><span>item 2</span></li>
  10. </ul>

Código Javascript:
Ver original
  1. var item = document.getElementById("item");
  2. var cont = document.getElementById("cont");
  3. item.onclick = function(){
  4. cont.style.display = (cont.style.display == 'none') ? 'block' : 'none';
  5. }

Aunque perdes mucha potencia si lo haces "a pelo" salvo que estés dispuesto a escribir mucho :)
  #5 (permalink)  
Antiguo 22/09/2011, 13:45
Avatar de IsaBelM
Colaborador
 
Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 5 meses
Puntos: 1012
Respuesta: menu de despliegue

no hay que escribir tanto y no se pierde nada de potencia. con esto prácticamente lo único que hay que hacer es agregar mas opciones al menú y editar el css a conveniencia

Cita:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="es" lang="es">
<head>
<meta http-equiv="Content-Type" content="application/xhtml; charset=utf-8" />
<title></title>
<style type="text/css">
html, body {
width: 100%;
height: 100%;
margin: 0;
padding: 0;
position: relative;
}

#navigation > li:hover {
cursor:pointer;
border: 1px solid #eee;
}

#navigation li > ul {
display: none;
}
</style>
</head>
<body>
<div id="menu">
* * <ul id="navigation">
* * * * <li>Coches
* * * * * * <ul>
* * * * * * * * <li><a href="#">Seat</a></li>
* * * * * * * * <li><a href="#">Fiat</a></li>
* * * * * * * * <li><a href="#">Mercedes</a></li>
* * * * * * </ul>
* * * * </li>
* * * * <li>Motos
* * * * * * <ul>
* * * * * * * * <li><a href="#">Yamaha</a></li>
* * * * * * * * <li><a href="#">Honda</a></li>
* * * * * * * * <li><a href="#">JJ Cobas</a></li>
* * * * * * </ul>
* * * * </li>
* * * * <li>Bandas
* * * * * * <ul>
* * * * * * * * <li><a href="#">Extremoduro</a></li>
* * * * * * * * <li><a href="#">Barricada</a></li>
* * * * * * * * <li><a href="#">Ñu</a></li>
* * * * * * </ul>
* * * * </li>
* * * * <li>Redes Sociales
* * * * * * <ul>
* * * * * * * * <li><a href="#">Facebook</a></li>
* * * * * * * * <li><a href="#">Hi5</a></li>
* * * * * * * * <li><a href="#">Twitter</a></li>
* * * * * * </ul>
* * * * </li>
* * </ul>
</div>
<script type="text/javascript">
function addListener(element, type, expression, bubbling)
{
bubbling = bubbling || false;

if(window.addEventListener) {
element.addEventListener(type, expression, bubbling);
return true;
} else if(window.attachEvent) {
element.attachEvent('on' + type, expression);
return true;
} else return false;
}

elem = document.getElementById('menu').firstChild;
while(true){
switch(elem.nodeName){
case 'UL':
elem = elem.firstChild;
break;
case 'LI':
addListener(elem, 'click', function(e){
childElem = this.firstChild;


// <-- Evitar que cuando se pulse sobre los hijos (submenus) se cierren -->

var event = e || window.event;
if(!event.target){
event.target = event.srcElement;
}
if(this != event.target){
//alert(this + ' - ' + event.target)
return false;
}
// <-- Fin -->



while(true){
if(childElem.nodeName == 'UL'){
break;
}
* * * * * * *
childElem = childElem.nextSibling;
if(childElem == null){ break; }
}
if(childElem != null){
childElem.style.display = childElem.style.display == 'block' ? 'none' : 'block';
}
});
break;
}
elem = elem.nextSibling;
if(elem == null){ break; }
}
</script>
</body>
</html>
  #6 (permalink)  
Antiguo 22/09/2011, 14:13
Avatar de cristian_cena
Colaborador
 
Fecha de Ingreso: junio-2009
Mensajes: 2.244
Antigüedad: 15 años, 5 meses
Puntos: 269
Respuesta: menu de despliegue

Cita:
Iniciado por IsaBelM Ver Mensaje
no hay que escribir tanto
pues, acabas de escribir una biblia cuando con jquery lo escribes en dos lineas XD.

Cita:
Iniciado por IsaBelM Ver Mensaje
no se pierde nada de potencia.
No probé tu código pero apuesto a que no se desliza (salvo que escribas a mano una función para eso lo que contradice tu primer argumento XD) y que decir de las posibilidades de selección de nodos.

En fín, cada cual con su cada quien.
  #7 (permalink)  
Antiguo 22/09/2011, 14:32
Avatar de IsaBelM
Colaborador
 
Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 5 meses
Puntos: 1012
Respuesta: menu de despliegue

es verdad que puede dar la falsa impresión que se ha de usar mucho código para hacer algo tan sencillo, pero en realidad no es así. habría que escribir miles de líneas de código para llegar alcanzar el peso que tiene la librería

no subestimes las posibilidades de javascript
Cita:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="es" lang="es">
<head>
<meta http-equiv="Content-Type" content="application/xhtml; charset=utf-8" />
<title></title>
<style type="text/css">
#capa1 {
width: 70px;
height: 70px;
background-color: yellow;
overflow: hidden;
}
</style>
<script type="text/javascript">
window.onload = function() {
document.getElementById('capa1').onclick = creaIntervalo;
}


window.onload = function() {
var capa = document.getElementById('capa1');
if(capa.addEventListener) {
capa.addEventListener('click', function() {
//alert(document.defaultView.getComputedStyle(capa, null).getPropertyValue('width'));
creaIntervalo(this.id, document.defaultView.getComputedStyle(capa, null).getPropertyValue('width'), // getComputedStyle() todos excepto ie8-
document.defaultView.getComputedStyle(capa, null).getPropertyValue('height')
)},
false
);
} else {
capa.attachEvent('onclick', function() {
//alert( document.styleSheets[0].rules[0].style['width']);
creaIntervalo(capa.id, document.styleSheets[0].rules[0].style['width'],
document.styleSheets[0].rules[0].style['height']
)}
);
}
}


function creaIntervalo(elem, w_bloque, h_bloque) {
var bloque = document.getElementById(elem);
var w_bloque = w_bloque;
var h_bloque = h_bloque;

if (typeof(boleano) == "undefined" || boleano == 0) {
boleano = 1;
despliega(bloque, w_bloque, h_bloque);
}else{
boleano = 0;
repliega(bloque, w_bloque, h_bloque);
}
}


function despliega(bloque, w, h) {
var ancho = parseInt(w);
var largo = parseInt(h);

if (ancho <= 210) {
ancho +=3;
bloque.style.width = ancho + 'px';
var intervalo = setTimeout(function(){despliega(bloque, ancho, largo)}, 8);
} else if (largo <= 210) {
largo += 3;
bloque.style.height = largo + 'px';
var intervalo = setTimeout(function(){despliega(bloque, ancho, largo)}, 8);
} else {
if (document.all && parseFloat(navigator.userAgent.match(/MSIE\s\d\.\d/).toString().split(' ')[1]) < 9) { // hay que cambiar las propiedades para ie8-
document.styleSheets[0].rules[0].style['width'] = ancho + 'px';
document.styleSheets[0].rules[0].style['height'] = largo + 'px';
}
clearTimeout(intervalo);
}
}


function repliega(bloque, w, h) {
var ancho = parseInt(w);
var largo = parseInt(h);

if (largo >= 73) {
largo -= 3;
bloque.style.height = largo + 'px';
var intervalo = setTimeout(function(){repliega(bloque, ancho, largo)}, 8);
} else if (ancho >= 73) {
ancho -=3;
bloque.style.width = ancho + 'px';
var intervalo = setTimeout(function(){repliega(bloque, ancho, largo)}, 8);
} else {
if (document.all && parseFloat(navigator.userAgent.match(/MSIE\s\d\.\d/).toString().split(' ')[1]) < 9) { // hay que cambiar las propiedades para ie8-
document.styleSheets[0].rules[0].style['width'] = ancho + 'px';
document.styleSheets[0].rules[0].style['height'] = largo + 'px';
}
clearTimeout(intervalo);
}
}
</script>
</head>
<body>

<div id="capa1">pulsa aquí!!<br /><br /><br /><br />Este texto no lo habías visto<br /><br /><br />pulsa otra vez!!</div>

</body>
</html>

Última edición por IsaBelM; 01/11/2011 a las 08:05 Razón: hacerlo compatible con navegadores antiguos
  #8 (permalink)  
Antiguo 22/09/2011, 16:01
Avatar de cristian_cena
Colaborador
 
Fecha de Ingreso: junio-2009
Mensajes: 2.244
Antigüedad: 15 años, 5 meses
Puntos: 269
Respuesta: menu de despliegue

uf isabel, disculpame, me aburrí
  #9 (permalink)  
Antiguo 23/09/2011, 00:31
Avatar de C2am  
Fecha de Ingreso: enero-2009
Ubicación: Rosario, Argentina
Mensajes: 2.005
Antigüedad: 15 años, 9 meses
Puntos: 306
Respuesta: menu de despliegue

Están buenos sus debates chicos (Isabel - Cristian), pero me parece que al ser el foro de css habría que apuntar hacia una solución en css, o en su defecto solicitar que sea movido al foro de javascript.
De todas formas, debo decir que estoy aprendiendo mucho de javascript :) gracias.
Saludos
__________________
El mundo nada puede contra un hombre que canta en la miseria.
-- Ernesto Sábato--
  #10 (permalink)  
Antiguo 30/09/2011, 19:23
Avatar de xlos_mas_pro  
Fecha de Ingreso: mayo-2011
Ubicación: Santiago
Mensajes: 359
Antigüedad: 13 años, 6 meses
Puntos: 11
Respuesta: menu de despliegue

gracias cristian_cena y IsaBelM me han servido de mucha ayuda y cristian_cena me e quedado con el codigo de isabel por que entiendo yo el codigo y prefiero entenderlo que tener una libreria que no entienda y cuando ocurra algun problema estar viendo miles de lineas que no se que son
pero igual probare con la libreria ya que no solo es para los menus trae mas opciones gracias a los dos
  #11 (permalink)  
Antiguo 30/09/2011, 19:30
Avatar de xlos_mas_pro  
Fecha de Ingreso: mayo-2011
Ubicación: Santiago
Mensajes: 359
Antigüedad: 13 años, 6 meses
Puntos: 11
Respuesta: menu de despliegue

haa y otra cosa cristian_cena me complica ese sitio de jquery ya que nunca se de donde descargo la libreria
jajajajja
  #12 (permalink)  
Antiguo 03/10/2011, 06:01
Avatar de tunait
Moderadora
 
Fecha de Ingreso: agosto-2001
Ubicación: Terok Nor
Mensajes: 16.805
Antigüedad: 23 años, 2 meses
Puntos: 381
Respuesta: menu de despliegue

¿y no serviría usar el momento "focus" desde css?
__________________
Javascript Códigos - Bambú difunde
  #13 (permalink)  
Antiguo 03/10/2011, 15:12
Avatar de IsaBelM
Colaborador
 
Fecha de Ingreso: junio-2008
Mensajes: 5.032
Antigüedad: 16 años, 5 meses
Puntos: 1012
Respuesta: menu de despliegue

Cita:
Iniciado por tunait Ver Mensaje
¿y no serviría usar el momento "focus" desde css?
ya aprovecho para trasladarte mi duda a ti también

Etiquetas: menu-desplegable
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 14:17.