La tercera versión, mantenimiento completo y ajax.
Categoría: Sin categoría
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: