Ver Mensaje Individual
  #1 (permalink)  
Antiguo 09/05/2012, 14:05
ocp001a
Colaborador
 
Fecha de Ingreso: mayo-2008
Ubicación: $MX['VZ']['Xalapa']
Mensajes: 3.005
Antigüedad: 15 años, 11 meses
Puntos: 528
[Aporte] selects dependientes Ajax 3 niveles XAJAX

En vista de los muchos post sobre select dependientes con selecciones por defecto y sobre todo por ajax que hay, decidí hacer este pequeño post.

Está definido para tres niveles, aunque se puede extender fácilmente a más agregando funciones o bien se podría evolucionar a una clase, pero creo que cumple su función para los novatos.

Funciona mediante xajax, lo cual (creo yo) hace más simple el ejemplo. Así, depende de tener la librería xajax instalada en la carpeta xajax.

Se basa en una tabla mysql sin relación con otra u otras, definida como:
tabla colonias_pais:
|estado|municipio|colonia|

Igualmente si se tiene una tabla relacional se puede modificar para que funcione así.

Código PHP:
Ver original
  1. <?php
  2. ini_set("display_errors", 1);
  3. require_once("base_datos.php");//incluimos los archivos de conexion
  4. @require_once("xajax/xajax_core/xajax.inc.php");
  5. $xajax = new xajax();
  6. $xajax->configure('javascript URI','xajax');
  7. ////Definimos las opciones por fecto. éstas pueden tomarse de $_POST, $_GET, $_SESSION, base de datos o lo que se requiera
  8. $estado_sel='';
  9. $municipio_sel='';
  10. $colonia_sel='';
  11.  
  12.  
  13. function busca_municipios($estado,$sel=''){//definimos la funcion que dado un estado busca los municipios
  14.     $con=conectar();//conectamos a la base de datos, esto dependera de como lo hagamos en nuestro script normalmente
  15.     $municipios=mysql_query("select distinct municipio from colonias_pais where estado='$estado'",$con);//buscamos los municipios del estado indicado
  16.     $js="
  17.     var sel=document.getElementById('municipio');//tomamos el select
  18.     sel.length=1;//En caso de tener opciones lo 'vaciamos', dejando solo la primera ";
  19.     $x=1;
  20.     while($m=mysql_fetch_assoc($municipios)){
  21.         $js.="
  22.         sel.length++;//agregamos una nueva opcion
  23.         sel.options[$x].value='$m[municipio]';//Indicamos el valor puede ser diferente al texto
  24.         sel.options[$x].text='$m[municipio]';";
  25.         if($m['municipio']==$sel)//si el municipio es la opcion por defecto
  26.             $js.="sel.options[$x].selected=true;";//indicamos que quede seleccionado
  27.         $x++;
  28.     }
  29.     mysql_free_result($municipios);
  30.     mysql_close();
  31.     $respuesta= new xajaxResponse();//creamos una respuesta tipo xajax
  32.     $respuesta->script($js);//asignamos el script js a la respuesta
  33.     return $respuesta; //respondemos el resultado
  34. }
  35. function busca_colonias($estado,$municipio,$sel=''){//definimos la funcion que dado un estado y municipio busca las colonias
  36.     $con=conectar();//conectamos a la base de datos, esto dependera de como lo hagamos en nuestro script normalmente
  37.     $colonias=mysql_query("select distinct colonia from colonias_pais where estado='$estado' and municipio='$municipio'");//ahora buscamos las colonias del estado y municipio
  38.     $js="
  39.     var sel=document.getElementById('colonia');//tomamos el select
  40.     sel.length=1;//En caso de tener opciones lo 'vaciamos', dejando solo la primera ";
  41.     $x=1;
  42.     while($c=mysql_fetch_assoc($colonias)){
  43.         $js.="
  44.         sel.length++;//agregamos una nueva opcion
  45.         sel.options[$x].value='$c[colonia]';
  46.         sel.options[$x].text='$c[colonia]';";
  47.         if($c['colonia']==$sel)//si la colonia es la opcion por defecto
  48.             $js.="sel.options[$x].selected=true;";//indicamos que quede seleccionada
  49.         $x++;
  50.     }
  51.     mysql_free_result($colonias);
  52.     mysql_close();
  53.     $respuesta= new xajaxResponse();//creamos una respuesta tipo xajax
  54.     $respuesta->script($js);//asignamos el script js a la respuesta
  55.     return $respuesta; //respondemos el resultado
  56. }
  57.  
  58. $xajax->registerFunction("busca_municipios");//registramos nuestras funciones php para que se puedan llamar via ajax
  59. $xajax->registerFunction("busca_colonias");
  60. $xajax->processRequest();//Indicamos a xajax que procese las respuestas.
  61. ?>
  62. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/2000/REC-xhtml1-20000126/DTD/xhtml1-transitional.dtd">
  63. <html>
  64. <head>
  65.     <?php $xajax->printJavascript();?>
  66.   </head>
  67.   <body>
  68.     <label>Estado</label>
  69.    <select name="estado" id="estado" onchange="xajax_busca_municipios(this.value,'<?php echo $municipio_sel?>');"><!-- Al cambiar, llamara la funcion que buscara los municipios del estado selecionado, pasando ademas el municipio por defecto si lo hubiera-->
  70.     <option value="">Seleccione...</option>
  71.     <?php
  72.         $con=conectar();//conectamos a la base de datos, esto dependera de como lo hagamos en nuestro script normalmente
  73.         $estados=mysql_query("select distinct estado from colonias_pais",$con);//distinct para obtener los estados sin repetirse
  74.         while($p=mysql_fetch_assoc($estados)){
  75.             echo "<option value=\"$p[estado]\" ";
  76.             if($p['estado']==$estado_sel)//$estado_sel seria la opción por defecto, puede ser obtenida por post, sesion, bd etc.
  77.                 echo 'selected';
  78.             echo ">$p[estado]</option>";
  79.         }
  80.         mysql_free_result($estados);
  81.         mysql_close();
  82.     ?>
  83.    </select>
  84.     <label>Municipio</label>
  85.    <select name="municipio" id="municipio" onchange="xajax_busca_colonias(document.getElementById('estado').value,this.value,'<?php echo $colonia_sel?>');"><!-- Ahora pasamos dos parametros, el estado y la colonia seleccionada-->
  86.         <option value="">Seleccione...</option>
  87.    </select>
  88.     <label>Colonia</label>
  89.    <select name="colonia" id="colonia">
  90.         <option value="">Seleccione...</option>
  91.    </select>
  92.    
  93.   </body>
  94. </html>