20 noviembre, 2018
Para desarrollar un buscador necesitas programar en Php, Mysql y Jquery para obtener respuestas en tiempo real con el evento KeyUp. Ejemplo con Jquery y Javascript nativo. Ajax o Fetch
Suscríbete a nuestro canal en Youtube
Suscríbirse¡Hola!. Desarrollar o mejor dicho programar un buscador puede resultar sencillo; claro para un programador, pero probablemente para alguien que esta empezando en el desarrollo de aplicaciones o páginas web puede resultar un poco dificil, es por ello que hice este pequeño tutorial.
CONTENIDOS:
Son aquellos buscadores de contenidos que requieren de una estrategia de búsqueda a partir de palabras claves o frases, buscan y recuperan la información que responde a esa descripción. Bien partiendo de esta definición podemos sintetizar que es una sección de nuestra página web destinada a proporcionar información de acuerdo a una consulta realizada por el usuario.
Tener un buscador en una página web es relevante siempre y cuando nuestro sitio web, tenga una sección dinámica, sea ésta una sección de noticias, un blog, etc. y que además sean de constante actualización e inserción de publicaciones. Es ahi donde un buscador tiene una razón de existir apropiada.
Vayamos al grano "crear un buscador con respuesta en tiempo real" para una página web require de conocimientos básicos de programación web, pero ¿Qué conocimientos? te estarás preguntando ¿Conocimientos en qué?, te respondo con una lista sencilla y numerada:
Pues, se trata de una caja de texto generalmente de color blanco, que esta en espera de leer una letra o letras, el usuario teclea o ingresa las letras de su búsqueda, ésta cadena de texto se envia al servidor, realiza una consulta en la base de datos y retorna un resultado que puede ser con los datos coincidentes o de lo contrario no retorna nada, solo un mensaje que no existen datos coincidentes.
Para que se pueda implementar un buscador en un sitio web es necesario tener la información almacenada normalmente en una Base de Datos MySql, para extraerla sin recargar toda la página es necesario implementar una arquitectura AJAX esta funcionalidad solo refrescará una parte de la página web para mostrar los resultados encontrados.
Quiero decir con esto ¿para qué se va construir el buscador?, es decir debes definir la finalidad, adelantandome un poco, voy a suponer que tenemos una web de consulta de usuarios, donde el operador de la página web quiere realizar consultas para obtener el nombre de un usuario, ésta actividad la quiere hacer muy rápidamente.
Entonces para desarrollar el proyecto definimos tres fases o etapas: que se ejecutan durante el proceso de desarrollo
Usaremos tecnologías web como:
Los archivos que se utilizarán durante el desarrollo del proyecto web tienen la siguiente estructura :
La base de datos solo contendrá una sola tabla, para comenzar abrimos el XAMPP, y creamos una base de datos llamada buscador.
Agregamos una única tabla llamada usuarios., esta solo tendrá 3 campos: id, nombre y bio, el primer campo se define como la clave primaria de la tabla. El código de la consulta para crear la tabla te lo muestro a continuación:
CREATE TABLE `usuarios` (
`id` int(11) NOT NULL,
`nombre` varchar(100) NOT NULL,
`bio` text NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
ALTER TABLE `usuarios`
ADD PRIMARY KEY (`id`);
Para gestionar la conexión a la base de datos y realizar las consultas necesarias trabajaremos con la siguiente clase PHP del link clase de conexión y consulta MYSQL en php
Entonces, usando sublime text creamos un documento html que contendrá la columna de nuestra app y agregamos dos recursos dentro del head.
Aqui integramos librerías y estilos para nuestro proyecto, esto debe de incluirse dentro de la etiqueta head de nuestra página web.
<link rel="stylesheet" href="lib/bootstrap.min.css">
<script src="lib/jquery.js"></script>
La librería responsive de Bootstrap, estilos que nos permite aplicar un diseño adecuado al proyecto.
Y la librería Jquery para darle interactividad, esta última realmente es la más importante para el funcionamiento del buscador, tambien podemos agregarla directamente desde Google link a Jquery
Aqui agregamos los elementos html como son el input que es el más importante, para ello usamos un componente de bootstrap
<div class="input-group mb-3">
<input type="text" class="form-control" id="txtbusca" placeholder="Buscar" aria-label="Buscar" aria-describedby="basic-addon2">
<div class="input-group-append">
<span class="input-group-text" id="basic-addon2">BUSCAR</span>
</div>
</div>
<div class="salida"></div>
Entonces al input text le agregamos un identificador llamado txtbusca, ademas de crear un div con el id salida que el que se llenará con los resultado de la consulta.
Aqui vamos a programar la interactividad con Javascript usando la librería Jquery, explicando la funcionalidad tenemos un input text con el id txtbusca con jquery escuchamos cada vez que se presiona una tecla cualquiera, esta acción lanza el evento keyup que captura el value es decir el caracter digitando en el input, con el método ajax lo enviamos a un documento php llamado salida.php, donde se realiza una consulta que retorna las coincidencias con la consulta. y se muestran en la web.
Código Jquery.
$(document).ready(function(){
$("#txtbusca").keyup(function(){
var parametros="txtbusca="+$(this).val()
$.ajax({
data: parametros,
url: 'salida.php',
type: 'post',
beforeSend: function () { },
success: function (response) {
$(".salida").html(response);
},
error:function(){
alert("error")
}
});
})
})
En el método success mostramos o cargamos lo que retorna nuestro ajax, en el div con la clase .salida donde estarán las respuestas de la consulta de salida.php.
Para ello vamos a emplear la API nativa de Javascript Fetch, veamos el código
Código Javascript:
document.getElementById("buscar").addEventListener("keyup", e=>{
var parametros = { txtbusca : e.target.value }
fetch("salida.php",{
method:'POST',
body: JSON.stringify(parametros),
dataType: "json",
headers:{
'X-Requested-With': 'XMLHttpRequest',
'Accept' : 'application/json',
'Content-Type' : 'application/json'
}
}).then(response => {
return response.json()
}).then(data =>{
salida.innerHTML = data
}).catch(error =>console.error(error));
})
Es script recibe la petición enviada desde la función Jquery lo procesa y retorna los resultados. Veamos el código salida.php
<?php
if(isset($_POST['txtbusca'])):
include "conexion.php";
$user=new ApptivaDB();
$u=$user->buscar("usuarios"," nombre like '%".$_POST['txtbusca']."%'");
$html="";
foreach ($u as $v)
$html.="<p>".$v['nombre']."</p>";
echo $html;
else:
echo "Error";
endif;
?>
Entonces, finalmente crear una buscador en tiempo real para un sitio web, como se ha visto, es una aplicación web, sencilla cuando usamos la tecnología Ajax para refrescar una sección de la página web sin la necesidad de recargar todo el documento. El buscador que he desarrollado se puede optimizar más, pero ello depende de los requerimientos del proyecto que estás desarrollando.
¿QUIERES VER OTRA VERSIÓN DEL BUSCADOR CON LARAVEL Y JAVASCRIPT?, talvez te puede interesar una versión con el Framework PHP de moda Laravel y usando solo Javascript con la API nativa fetch en el siguiente link Buscador Laravel en tiempo real con JS puedes encontrar más información y el código del desarrollo.
Hasta un próximo tutorial de programación web. Recuerda que puedes seguirnos en nuestro canal de Youtube, estamos con Codea
Leido 43244 veces
Curso MVC PHP MySQL desarrollo de una página web administrable
Descarga del código fuente
USD 10.00
© Todos los derechos reservados Codea App | ...de frente al código!!! | 2020 - 2024