Foros del Web » Programando para Internet » PHP »

Problema con Select Dependientes

Estas en el tema de Problema con Select Dependientes en el foro de PHP en Foros del Web. Buenas tardes a todos, tengo un problema con un sistema que estoy haciendo, tengo un index_tipificar_iframe.php donde hago un llamado a un frame que se ...
  #1 (permalink)  
Antiguo 03/10/2009, 10:38
 
Fecha de Ingreso: agosto-2009
Mensajes: 59
Antigüedad: 14 años, 8 meses
Puntos: 0
Exclamación Problema con Select Dependientes

Buenas tardes a todos, tengo un problema con un sistema que estoy haciendo, tengo un index_tipificar_iframe.php donde hago un llamado a un frame que se llama index_tipificar.php. este archivo en el action del form llama a los frames selec 2 selec3 y asi sucesivamente, en total son 5, todos los valores de estos select los traigo de una bd, el problema que tengo es el siguiente, cuando tengo el primer select donde me salen la opciones Asesoria tecnica, informacion requerimientos, reclamos, selecciono por ejemplo requerimientos, esto me llama al siquiente frame donde esta el segundo select y con la instruccion de bd me imprime las categorias que corresponden a requerimientos, en fin el problema es que necesito que al llamar al segundo select en el primero se mantenga la seleccion anterior, y lo hace pero lo repite por toda la lista, es decir

Lista desplegable

Requerimientos Cambios en la linea

Informacion

Requerimientos

Asesoria Tecnica

Requerimientos

Reclamos


y esto me ocurre con todos, aqui les dejo el codigo

index_tipificar.php
Código HTML:
<script>


var vacia = "";

function categorias(){
   document.miForm.action = "selec2.php";
   document.miForm.selec1.value = vacia;
   document.miForm.submit()
} 
</script>
<form name="miForm" id="miForm" method="post">
<table width="0" border="0" cellspacing="0">
  <tr>
    <td>Categorias:</td>
    <td><?

include ("conex.php");
$link=Conectarse();
$sSQL="Select * From categorias Order By seleccion";
$result=mysql_query($sSQL);

echo '<select name="selec1" id="selec1" onchange="categorias()">';

//Generamos el menu desplegable
while ($row=mysql_fetch_array($result))
{echo '<option>'.$row["seleccion"];}

?>
</select></td>
  </tr>
</table>
</form> 
selec2.php
Código HTML:
 <script>


var vacia = "";

function categorias(){
   document.miForm.action = "selec2.php";
   document.miForm.selec1.value = vacia;
   document.miForm.submit()
} 
function categorias2(){
   document.miForm.action = "selec3.php";
   document.miForm.submit()
} 
</script>           
                 
                  <?php
  
$selec1 = $_POST['selec1'];
$selec2 = $_POST['selec2'];

 ?>
<form name="miForm" id="miForm" method="post">
<table width="0" border="0" cellspacing="0">
  <tr>
    <td>Categorias:<?

include ("conex.php");
$link=Conectarse();
$sSQL="Select * From categorias Order By seleccion";
$result=mysql_query($sSQL);

echo '<select name="selec1" id="selec1" onchange="categorias()">';

//Generamos el menu desplegable
while($row=mysql_fetch_array($result))
{echo '<option selected="selected">'.$selec1.'</option>
<option>'.$row["seleccion"];}

?>
</select></td>
    <td><?
$sSQL="Select * From categorias2 where relacion='$selec1' Order By seleccion";
$result=mysql_query($sSQL);

echo '<select name="selec2" id="selec2" onchange="categorias2()">';

//Generamos el menu desplegable
while ($row=mysql_fetch_array($result))
{echo '<option>'.$row["seleccion"];}

?>
</select></td>
  </tr>
</table>
</form> 

si alguien me puede ayudar se lo agradecere infinatemente.

Saludos
  #2 (permalink)  
Antiguo 03/10/2009, 10:56
 
Fecha de Ingreso: abril-2009
Ubicación: Miami
Mensajes: 182
Antigüedad: 15 años
Puntos: 8
Sonrisa Respuesta: Problema con Select Dependientes

Hola ... bueno, para lo que estás haciendo te recomiendo AJAX, se usa exclusivamente para lo que pretendes .. de todas formas, prueba poniendo onsubmit="return false" en tu FORM, algo así como:

<form action="" method="post" onsubmit="return false">

y dime si te resulta .. salu2!!!
__________________
-----------------------------------
Éxitos !!! .. joao
  #3 (permalink)  
Antiguo 03/10/2009, 11:29
Avatar de mortiprogramador
Colaborador
 
Fecha de Ingreso: septiembre-2009
Ubicación: mortuoria
Mensajes: 3.805
Antigüedad: 14 años, 7 meses
Puntos: 214
Respuesta: Problema con Select Dependientes

Hola
Pues si te entendí bien, lo que quieres es dejar selected lo que escogiste en el primer select, que es selec1 si no estoy mal

Ahora, podrias hacer lo siguiente

tienes esta variable

$selec1 = $_POST['selec1'];

y pues como esa variable tendría el option que escogiste en el selec1, lo que
tendrias que hacer es en el while de selec1 agregar un if en donde preguntes
si el option que estas imprimiendo es igual a esa variable, entonces
haga selected ese option
Con eso te debería funcionar
Prueba y nos comentas
saludos
  #4 (permalink)  
Antiguo 03/10/2009, 11:49
 
Fecha de Ingreso: agosto-2009
Mensajes: 59
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: Problema con Select Dependientes

muchas gracias a los dos, entiendo parcialmente lo que me dices del if pero cuando lo introduzco no hace nada. podrias ayudarme?
  #5 (permalink)  
Antiguo 03/10/2009, 12:13
Avatar de mortiprogramador
Colaborador
 
Fecha de Ingreso: septiembre-2009
Ubicación: mortuoria
Mensajes: 3.805
Antigüedad: 14 años, 7 meses
Puntos: 214
Respuesta: Problema con Select Dependientes

Bueno, mira este ejemplo


Código PHP:
<select name="id_origen" id="id_origen" onchange="submit()">
<?php
$idorigen 
$_POST['id_origen'];
do {
?>
<option value="<?php echo $row_origen['id_origen']?>"<?php if ($row_origen['id_origen'] == $idorigen) {echo "selected=\"selected\"";} ?>><?php echo $row_origen['origen']?></option>
<?php
} while ($row_origen mysql_fetch_assoc($origen));
$rows mysql_num_rows($origen);
if(
$rows 0) {
mysql_data_seek($origen0);
$row_origen mysql_fetch_assoc($origen);
}
?>
        </select>
Como podras ver, la variable $idorigen recoge el valor post del select (en mi ej el select esta dentro de un form que tiene el method en post)
y si ves en la parte donde asigno los option tengo un if donde pregunto si lo que esta mostrando es igual a la variable $idorigen entonces que haga ese option selected, que creo es lo que necesitas
Espero te sirva
saludos
  #6 (permalink)  
Antiguo 03/10/2009, 12:31
 
Fecha de Ingreso: agosto-2009
Mensajes: 59
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: Problema con Select Dependientes

Muchas gracias hermano de todas formas ya lo habia resuelto con esto


Código PHP:
      <script>


var vacia = "";

function categorias(){
   document.miForm.action = "selec2.php";
   document.miForm.selec1.value = vacia;
   document.miForm.submit()

function categorias2(){
   document.miForm.action = "selec3.php";
   document.miForm.submit()

</script>           
                 
                  <?php
  
$selec1 
$_POST['selec1'];
$selec2 $_POST['selec2'];

 
?>
<form name="miForm" id="miForm" method="post">
<table width="0" border="0" cellspacing="0">
  <tr>
    <td>Categorias:<?

include ("conex.php");
$link=Conectarse();
$sSQL="Select * From categorias Order By seleccion";
$result=mysql_query($sSQL);

echo 
'<select name="selec1" id="selec1" onchange="categorias()">';

//Generamos el menu desplegable
while ($row=mysql_fetch_array($result))
{if (
$row['seleccion']==$selec1) {
        echo 
"<option selected>".$selec1."</option>";
    } else {
        echo 
"<option>".$row['seleccion']."</option>";}
}
?>
</select></td>
    <td><?
$sSQL
="Select * From categorias2 where relacion='$selec1' Order By seleccion";
$result=mysql_query($sSQL);

echo 
'<select name="selec2" id="selec2" onchange="categorias2()">';

//Generamos el menu desplegable
while ($row=mysql_fetch_array($result))
{echo 
'<option>'.$row["seleccion"];}

?>
</select></td>
  </tr>
</table>
</form>
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 05:08.