Foros del Web » Programando para Internet » PHP »

¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Estas en el tema de ¿Como mostrar datos dependientes al seleccionar un campo del formulario? en el foro de PHP en Foros del Web. Hola a todos! Necesito ayuda con lo siguiente: Tengo un formulario, en uno de los campos hago una busqueda, escribo una palabra y se van ...
  #1 (permalink)  
Antiguo 09/04/2013, 05:46
 
Fecha de Ingreso: agosto-2009
Ubicación: Venezuela
Mensajes: 82
Antigüedad: 14 años, 8 meses
Puntos: 0
Pregunta ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Hola a todos! Necesito ayuda con lo siguiente: Tengo un formulario, en uno de los campos hago una busqueda, escribo una palabra y se van desplegando las opciones tipo google (con autocompletar), esto funciona bien, pero quiero que cuando seleccione el valor deseado en ese campo con un clic, automaticamente se me llenen los siguientes campos con los demas valores correspondientes al seleccionado, es decir, selecciono el nombre del medicamento y en los siguientes campos se llenan automaticamente la forma farmaceutica, via de administracion, y marcas comerciales, todo esto esta en una misma tabla de mysql llamada medicamento. Disculpen que me haya extendido pero queria explicarme.

Aqui el codigo que tengo:

<html >
<head>
<title>Sistema</title>
<script language="JavaScript" src="js/jquery-1.5.1.min.js"></script>
<script language="JavaScript" src="js/jquery-ui-1.8.13.custom.min.js"></script>
<link type="text/css" href="css/ui-lightness/jquery-ui-1.8.13.custom.css" rel="stylesheet" />
</head>

<body>

<div>
<H1>Llene todos los datos del formulario:</H1>
<BR>

<form name="form1" action="recipepdf.php" method="POST">
<td>Escriba nombre del medicamento:</td>
<?php
include("conexion.php");
$con = "select * from medicamento";
$query = mysql_query($con);
?>

<script>
$(function() {
<?php
while($row= mysql_fetch_array($query)) {//se reciben los valores y se almacenan en un arreglo
$elementos[]= '"'.$row['med_comercial_1'].'"';
}
$arreglo= implode(", ", $elementos);//junta los valores del array en una sola cadena de texto
?>

var availableTags=new Array(<?php echo $arreglo; ?>);//imprime el arreglo dentro de un array de javascript
$( "#tags" ).autocomplete({
source: availableTags
});
});
</script>

<label for="tags"></label>
<input id="tags" name="nombre">

<td>Forma Farmaceutica:</td>
<td><input name="present" type="text" id="present" size="30"></td><br>

<td>Via de Administracion:</td>
<td><input name="viadmin" type="text" id="viadmin" size="30"></td><br>

<td>Marcas Comerciales:</td>
<td><input name="marca" type="text" id="marca" size="30"></td><br>

</tr><br>
<input name="Enviar" type="submit" value="PDF">
</form>

</BODY>
</HTML>

Les agradezco la ayuda
  #2 (permalink)  
Antiguo 09/04/2013, 06:12
Avatar de rottenp4nx  
Fecha de Ingreso: octubre-2012
Ubicación: Santiago
Mensajes: 417
Antigüedad: 11 años, 6 meses
Puntos: 36
Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Puedes usar Ajax y JSON

y el evento que necesitas es change que viene en la libreria Jquery

Cuando se haga clic en un medicamente, se ejecuta el evento change, ejecutas ajax y traes los datos por JSON, y completas los campos

Saludos
  #3 (permalink)  
Antiguo 09/04/2013, 08:58
 
Fecha de Ingreso: agosto-2009
Ubicación: Venezuela
Mensajes: 82
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Gracias! Ya estoy investigando, pero me podrias dar un ejemplo sobre el caso? es que no he trabajado con ajax y json.. Por lo menos se que hay una solucion! Gracias!
  #4 (permalink)  
Antiguo 09/04/2013, 14:40
Avatar de rottenp4nx  
Fecha de Ingreso: octubre-2012
Ubicación: Santiago
Mensajes: 417
Antigüedad: 11 años, 6 meses
Puntos: 36
Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Supongamos que cada medicamento tiene su PK numerica por ejemplo

Código HTML:
Ver original
  1. <select id="listaMedicamentos">
  2. <option selected value="null"></option>
  3. <option value="1">Medicamento 1</option>
  4. <option value="2">Medicamento 2</option>
  5. <option value="3">Medicamento 3</option>
  6. <div id="resMedicamento"></div>

Javascript/Jquery

Código Javascript:
Ver original
  1. $(document).ready(
  2.    $("#listaMedicamentos").change(cargarMedicamento);
  3. );
  4.  
  5. function cargarMedicamento(){
  6.     var x = $(this).val();
  7.    $.ajax(
  8.        data: "idMedicamento="+x,
  9.        type: "post",
  10.        url: "procesar.php",
  11.        dataType: "json",
  12.        beforeSend: function(){
  13.               $("#resMedicamento").html("Cargando Medicamento");
  14.        },
  15.        success: function(datos){
  16.               alert(datos);
  17.               //Aqui agregar los datos a sus respectivos campos
  18.        }
  19.    );
  20. }

El PHP, procesar.php

Código PHP:
Ver original
  1. <?php
  2.  
  3.    $id = $_POST['idMedicamento'];
  4.    //conexion a la bd
  5.    $sql = "Select * from medicamentos where id = $id";
  6.    $reg = mysql_query($sql);
  7.    $r = mysql_fetch_assoc($reg);
  8.    echo json_encode($r);
  9. ?>

Solo faltaría poner los datos a los input text, que seria en success en JS

Saludos
  #5 (permalink)  
Antiguo 09/04/2013, 15:40
 
Fecha de Ingreso: marzo-2013
Ubicación: cali
Mensajes: 9
Antigüedad: 11 años, 1 mes
Puntos: 0
Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

hola amigo yo presente el mismo inconveniente esta semana y luego de mucho investigar encontre el codigo que necesitaba para este problemita espero que te sirva igualmente.
consta de 3 partes te voy a enviar el codigo tal cual como yo lo utilice.
te voy a poner el link con el codigo la unica diferencia es que yo utilizo una bd postgres solo debes cambiar los comando y ya.

http://strauss62.host30.conexcol.net.co/codigos/autocompletar.zip

si quieres saber si te esta trabajando bn activa la consola del browser asi te das cuenta si te falta algo

si necesitas algo me escribes buena suerte

amigo se me olvido decirte funciona bien el unico inconveniente que tiene y el cual no he podido solucionar es si el nombre contiene acentos no me los trae y me muestra el campo como null si encuentras la forma de solucionarlo te lo agradeceria

Última edición por strauss62; 09/04/2013 a las 15:56
  #6 (permalink)  
Antiguo 10/04/2013, 12:51
 
Fecha de Ingreso: agosto-2009
Ubicación: Venezuela
Mensajes: 82
Antigüedad: 14 años, 8 meses
Puntos: 0
Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

Muchas gracias por su ayuda, revisare sus propuestas y cualquier duda volvere a molestar ya q no he trabajado con ajax, gracias!
  #7 (permalink)  
Antiguo 20/05/2013, 21:44
 
Fecha de Ingreso: julio-2009
Mensajes: 48
Antigüedad: 14 años, 9 meses
Puntos: 0
De acuerdo Respuesta: ¿Como mostrar datos dependientes al seleccionar un campo del formulario?

hola strauss62 disculpa que te molesto a esta altura, pero es que ando con un problema de autocompletar un campo; y es exactamente como tú lo utilizas la forma de la que yo la necesito porque estoy trabajando con postgres tmb y me sirve de mucho tu ejemplo, sólo que nosé qué información contiene exactamente el archivo llamado conectar.php, que se llama desde el archivo consulta_empresas.php, porque imagino que hay una función ahí, pero no imagino cómo es, me podrías decir cómo es?? o mandarmela para implementarla en lo que toy haciendo?? muchas gracias y perdona que me extendí tanto para explicarte mi problema...

Etiquetas: automaticamente, campos
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 07:12.