Ver Mensaje Individual
  #3 (permalink)  
Antiguo 15/05/2008, 07:28
Avatar de T4ke0veR
T4ke0veR
 
Fecha de Ingreso: agosto-2007
Ubicación: Quito - Ecuador
Mensajes: 1.720
Antigüedad: 16 años, 8 meses
Puntos: 28
Re: Como crear 2 menus dependientes uno del otro??

creo q deberias combinarlo un poco con java... a er si esto t sirve!!!

un archivo llamado conexion
Código PHP:
<?php
function conectar()
{
    
mysql_connect("localhost""root""");
    
mysql_select_db("nombre_db");
}

function 
desconectar()
{
    
mysql_close();
}
?>
luego un archivo css llamado select_dependientes.css
Código PHP:
#demoIzq, #demoDer { border:1px dashed; width:296px; background-color:#EAEAEA; text-align:center; }

#demoDer { float:right; }

select width:220px; } 
otro select_dependistes.js <- javascript
Código PHP:
function nuevoAjax()

    
/* Crea el objeto AJAX. Esta funcion es generica para cualquier utilidad de este tipo, por
    lo que se puede copiar tal como esta aqui */
    
var xmlhttp=false;
    try
    {
        
// Creacion del objeto AJAX para navegadores no IE
        
xmlhttp=new ActiveXObject("Msxml2.XMLHTTP");
    }
    catch(
e)
    {
        try
        {
            
// Creacion del objet AJAX para IE
            
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
        }
        catch(
E)
        {
            if (!
xmlhttp && typeof XMLHttpRequest!='undefined'xmlhttp=new XMLHttpRequest();
        }
    }
    return 
xmlhttp
}

// Declaro los selects que componen el documento HTML. Su atributo ID debe figurar aqui.
var listadoSelects=new Array();
listadoSelects[0]="paises";
listadoSelects[1]="estados";

function 
buscarEnArray(array, dato)
{
    
// Retorna el indice de la posicion donde se encuentra el elemento en el array o null si no se encuentra
    
var x=0;
    while(array[
x])
    {
        if(array[
x]==dato) return x;
        
x++;
    }
    return 
null;
}

function 
cargaContenido(idSelectOrigen)
{
    
// Obtengo la posicion que ocupa el select que debe ser cargado en el array declarado mas arriba
    
var posicionSelectDestino=buscarEnArray(listadoSelectsidSelectOrigen)+1;
    
// Obtengo el select que el usuario modifico
    
var selectOrigen=document.getElementById(idSelectOrigen);
    
// Obtengo la opcion que el usuario selecciono
    
var opcionSeleccionada=selectOrigen.options[selectOrigen.selectedIndex].value;
    
// Si el usuario eligio la opcion "Elige", no voy al servidor y pongo los selects siguientes en estado "Selecciona opcion..."
    
if(opcionSeleccionada==0)
    {
        var 
x=posicionSelectDestinoselectActual=null;
        
// Busco todos los selects siguientes al que inicio el evento onChange y les cambio el estado y deshabilito
        
while(listadoSelects[x])
        {
            
selectActual=document.getElementById(listadoSelects[x]);
            
selectActual.length=0;
            
            var 
nuevaOpcion=document.createElement("option"); nuevaOpcion.value=0nuevaOpcion.innerHTML="Selecciona Opci&oacute;n...";
            
selectActual.appendChild(nuevaOpcion);    selectActual.disabled=true;
            
x++;
        }
    }
    
// Compruebo que el select modificado no sea el ultimo de la cadena
    
else if(idSelectOrigen!=listadoSelects[listadoSelects.length-1])
    {
        
// Obtengo el elemento del select que debo cargar
        
var idSelectDestino=listadoSelects[posicionSelectDestino];
        var 
selectDestino=document.getElementById(idSelectDestino);
        
// Creo el nuevo objeto AJAX y envio al servidor el ID del select a cargar y la opcion seleccionada del select origen
        
var ajax=nuevoAjax();
        
ajax.open("GET""select_dependientes_proceso.php?select="+idSelectDestino+"&opcion="+opcionSeleccionadatrue);
        
ajax.onreadystatechange=function() 
        { 
            if (
ajax.readyState==1)
            {
                
// Mientras carga elimino la opcion "Selecciona Opcion..." y pongo una que dice "Cargando..."
                
selectDestino.length=0;
                var 
nuevaOpcion=document.createElement("option"); nuevaOpcion.value=0nuevaOpcion.innerHTML="Cargando...";
                
selectDestino.appendChild(nuevaOpcion); selectDestino.disabled=true;    
            }
            if (
ajax.readyState==4)
            {
                
selectDestino.parentNode.innerHTML=ajax.responseText;
            } 
        }
        
ajax.send(null);
    }

__________________
Diseño gráfico, Web, imagen corporativa, publicidad ...