Foros del Web » Programando para Internet » PHP »

Problemas con check en PHP y MySql

Estas en el tema de Problemas con check en PHP y MySql en el foro de PHP en Foros del Web. Que tal Sres del foro... Ante todo disculpen mi ignorancia o desconocimiento de la herramieta Php y Mysql. Mi dificultad es la siguiente: Deseso actualizar ...
  #1 (permalink)  
Antiguo 12/11/2009, 21:26
 
Fecha de Ingreso: noviembre-2009
Mensajes: 8
Antigüedad: 14 años, 5 meses
Puntos: 0
Problemas con check en PHP y MySql

Que tal Sres del foro...

Ante todo disculpen mi ignorancia o desconocimiento de la herramieta Php y Mysql.

Mi dificultad es la siguiente:

Deseso actualizar un registro que se encuentra almacenado en una base de datos MySql, el contenido del registro lo cargo, en el From de mi página, sin embargo tengo problemas con la asignación del valor a un check de control la carga del check la hago de esta forma

echo "<td><font face=arial size=2><h0 style=color:blue>Activo</td><td><input type='checkbox' name='chk_activo' value='". $row["activo"]."'><br></td></tr>";

La palabra resaltada es el valor procedente de la base de datos leída mendiante PHP, sin embargo, no carga el valor en la pantalla, y al momento de actualizar solo me acepta el valor cuando esta activado.

He buscado en muchos temas tanto de aqui como de otras páginas y no logro encontrar ayuda al respecto. Recurro a ustedes, porque he visto que en este foro tienen muchos temas de interes, lo cual indica que hay mucos conocedores de la materia.

Agradezco la información o pistas que me pueden brindar el respecto, y si mis detalles son algo escuetos, me lo hacen saber para extenderme en el código

Saludos y gracias anticipadamente
  #2 (permalink)  
Antiguo 12/11/2009, 21:36
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Problemas con check en PHP y MySql

Cita:
Iniciado por yovrod Ver Mensaje
[...] sin embargo, no carga el valor en la pantalla, y al momento de actualizar solo me acepta el valor cuando esta activado [...]
de hecho, así es el comportamiento de los checkboxes

solo se envían los que han sido seleccionados, no mas...

suerte!!
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 13/11/2009, 09:02
 
Fecha de Ingreso: noviembre-2009
Mensajes: 8
Antigüedad: 14 años, 5 meses
Puntos: 0
Respuesta: Problemas con check en PHP y MySql

Entonces no existe respuesta para este inconveniente...? me suena un poco extraño que una herramienta tan reconocida y utilizada no contemple esto ya sea por si misma o bien con el complemento de otra que es lo que busco.

Gracias por su atención.
  #4 (permalink)  
Antiguo 13/11/2009, 09:59
 
Fecha de Ingreso: noviembre-2009
Mensajes: 8
Antigüedad: 14 años, 5 meses
Puntos: 0
Respuesta: Problemas con check en PHP y MySql

Como lo dije anteriormente me resulta extraño que no hubiese solución, sin embargo entre al foro porque pensé que alguien había pasado por esto y de alguna manera lo había solucionado, pues yo si, con pura programación, que aunque tal vez no se la más adecuada me es funcional y se las dejo para contribuir por si alguien tiene el mismo problema.

Primero: Como no podía obtener el valor del CHECKBOX en mi FORM con PHP, primero hice un IF para tomar la opcion de seleccionado o no según el dato obtenido de la base de datos de esta forma

if ( $row["activo"]==1){
echo "<td><font face=arial size=2><h0 style=color:blue>Activo</td><td><input type='checkbox' name='chk_activo' value='". $row["activo"]."' checked><br></td></tr>";
}
else{
echo "<td><font face=arial size=2><h0 style=color:blue>Activo</td><td><input type='checkbox' name='chk_activo' value='0' ><br></td></tr>";
}

Segungo: Creo un campo invisible solo para manejar el valor de la base de datos y así enviarlo al POST de este FORM (esto no altera el FORM ni la vista del usuario):

echo"<br>";
echo "<div id='activo' style='position: absolute; left: 240px; top: 100px; visibility: hidden;' align='left'>";
echo"<input type='textarea' id='activo' name='activo' style='width: 71px; height: 26px;' value='".$row["activo"]."' maxlength='255'></div>";
echo"<br>";

Y tercero: Es del lado actualizador de la información en PHP, en donde valido la condición del CHECKBOX si envia error o no, y eso lo compruebo con el ISSET, entonces juego con la variabe proveniente del campo oculto así como sigue:

if(isset($_POST['chk_activo']))
{
if ($_POST['activo']=1){
$chk_activo=1;
}
else{
$chk_activo=0;
}
}
else{
if ($_POST['activo']=1){
$chk_activo=0;
}
else{
$chk_activo=1;
}
}

no se tal vez sea muy extenso, pero a mi ya me funciona, de todas formas si existe una manera menos complicada agradecería que la colocaran en este TEMA para que el resto de los foristas tenga a escoger, segun su apreciaciones.

Gracias señores por obligarme a tratar de resolver mi problema.

Saludos a todos.
  #5 (permalink)  
Antiguo 13/11/2009, 10:10
Avatar de darkasecas  
Fecha de Ingreso: marzo-2005
Ubicación: SantaCata, NL, Mexico
Mensajes: 1.553
Antigüedad: 19 años, 1 mes
Puntos: 77
Respuesta: Problemas con check en PHP y MySql

Si hay una forma mas simple

Ponerlo como seleccionado si el valor de la bd es 1, si no, pues no :p
Código PHP:
<input type="checkbox" name="chk_activo" value="1" <?php echo ($row["activo"]==1?'checked':'');?> />
y si se envia el dato, quiere decir que se selecciono, por lo que le damos valor de 1, si no, pues no se selecciono y le damos valor de 0
Código PHP:
$chk_activo=(isset($_POST['chk_activo'])?1:0); 
Aunque esta bien que lo hayas resuelto por ti mismo en vez de esperar a que te dieran el codigo hecho aca :)
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 03:44.