Un tema muy sencillo para entender los mecanismos:
Categoría: Sin categoría
Mini framework version 3
La tercera versión, mantenimiento completo y ajax.
Ejercicio detalle
Función en adb:
function creaSelect($tabla,$campo,$id="selRegistro"){ $filas=$this->seleccionar($tabla,0,-1); ?> <select id="<?=$id?>"> <option value="0">Seleccione...</option> <?php foreach($filas as $fila){ ?> <option value="<?=$fila["id$tabla"]?>"><?=$fila["$campo"]?></option> <?php } ?> </select> <?php }
Detalle:
require_once 'adb.php'; $adb=new adb(); $adb->creaSelect('test', 'nombre');
Detalle, script:
$(function() { $( "#selRegistro" ).change(function(){ console.log($(this).val()); $.get("ajax.php",{detalle:1,tabla:'test',id:$(this).val()}, function(data, status){ $("#resultado").html(data); }); }); });
ajax.php
if (isset($_GET['detalle']) && isset($_GET['id']) && isset($_GET['tabla'])){ $filas=$adb->seleccionarId($_GET['tabla'], $_GET['id']); echo json_encode($filas); }
Cambio en seleccionar:
$sql = "select * from $tabla " . (empty($cond) ? '' : " where $cond ") . (($numero!=-1)?" limit $inicio,$numero ":"");
Cambios en adb para introducir ajax
Función en adb:
function seleccionarAuto($tabla, $campo, $term="",$inicio = 0, $numero = 10) { try { $sql = "select * from $tabla where $campo like '%$term%' limit $inicio,$numero "; $sqlst = $this->con->prepare($sql); $sqlst->execute(); $this->filas = $sqlst->fetchAll(PDO::FETCH_ASSOC); $res=array(); foreach ($this->filas as $fila){ $res[]=$fila[$campo]; } return $res; } catch (Exception $ex) { $this->tratarError("seleccionar", $ex->getMessage(), $sql); die($ex->getMessage()); } }
La página ajax.php:
require_once "adb.php"; $adb=new adb(); if (isset($_GET['buscar']) && isset($_GET['tabla']) && isset($_GET['campo'])){ $filas=$adb->seleccionarAuto($_GET['tabla'],$_GET['campo'],$_GET['term'],0,10); echo json_encode($filas); }
La llamada:
$(function() { $( "#buscar" ).autocomplete({ source: "ajax.php?buscar=1&tabla=test&campo=nombre", minLength: 2, }); });
Busqueda con get (ajax 2)
$nombres="ana,juan,eva,luis,rosa,jose,marc"; $nombres=explode(",",$nombres); if (!empty($_GET['cadena'])) { $res=""; foreach($nombres as $nombre){ if (strpos($nombre,$_GET['cadena'])!==false){ $res.=$nombre." "; } } echo $res; } else{ echo "Faltan datos"; }
HTML:
$(document).ready(function(){ $("#nombre").keyup(function(){ var nom=$("#nombre").val(); $.get("busqueda.php",{cadena:nom}, function(data, status){ $("#resultado").html(data); console.log("Datos: " + data + "\nStatus: " + status); }); }); });
Mini framework version 2
Segunda versión del miniframework, con funciones HTML incluídas:
Mini framework version 1
Esta es la primera versión al completo del framework de clase: