This content originally appeared on DEV Community and was authored by URIAN VIERA
¿Alguna vez te has preguntado cómo mejorar la experiencia del usuario en tus aplicaciones web durante las solicitudes y procesos asincrónicos? 😫 No hay nada peor que un usuario mirando una pantalla en blanco, sin saber si la app está haciendo algo. ¡Es hora de cambiar eso!
Presentamos Loading Request, un paquete npm versátil y fácil de integrar que muestra indicadores de carga en tus aplicaciones web. Compatible con frameworks populares como React, Vue, Angular, Svelte, Next.js, Astro y más, este paquete está diseñado para mejorar la percepción de rendimiento de tus aplicaciones con spinners, barras de progreso y otros indicadores visuales. 🎉
En este artículo, te mostraré cómo instalar y usar Loading Request para que puedas empezar a mejorar la usabilidad y la experiencia de tus usuarios en muy poco tiempo. ¡Vamos allá! 🚀
Loading Request
Loading Request es un paquete npm versátil, que nace con el fin de resolver una necesidad muy común en los desarrolladores. Loading Request muestra indicadores de carga en aplicaciones web. Compatible con frameworks como React, Vue, Angular, Svelte, Next.js, Astro y más, mejora la experiencia del usuario con spinners, barras de progreso y otros indicadores visuales durante solicitudes y procesos asincrónicos en JavaScript. Personalizable y fácil de integrar, Loading Request simplifica la implementación de indicadores de carga en aplicaciones web, mejorando la usabilidad y la percepción de rendimiento.
Casos de uso:
Procesar el envio de un formulario
Filtrado dinámico en Next.js haciendo uso del paquete Loading Request
👉 Código
Instalación
$ npm install loading-request --save
$ yarn add loading-request
Caracteristicas
- Fácil de usar: Implementa indicadores de carga fácilmente en tu aplicación web con solo unas pocas líneas de código.
- Compatible con múltiples frameworks: Funciona sin problemas con frameworks populares como React, Vue, Angular, y Svelte.
- Personalización flexible: Permite personalizar el color del spinner y del texto del mensaje de carga según las necesidades del usuario.
- Integración rápida: Instalación simple a través de npm o yarn, listo para usar en minutos.
- Funcionalidad asincrónica: Soporta operaciones asíncronas como carga de datos, envío de formularios, y navegación entre páginas.
- Animaciones suaves: Utiliza animaciones CSS para proporcionar una experiencia de usuario fluida.
- Ligero y eficiente: Diseñado para tener un impacto mínimo en el rendimiento de la aplicación.
- Documentación clara y detallada: Incluye ejemplos prácticos y documentación completa para facilitar la implementación y configuración.
- Actualizaciones regulares: Mantenido activamente con mejoras y actualizaciones periódicas.
- Licencia abierta: Publicado bajo licencia ISC, permitiendo su uso en proyectos comerciales y personales sin restricciones.
Ejemplo Práctico en React.js
import { showLoading, hideLoading } from "loading-request";
import "loading-request/dist/index.css";
const App = () => {
const handleShowLoading = () => {
showLoading({
message: "Cargando...",
spinnerColor: "#f3752b",
textLoadingColor: "#EE5E09",
});
hideLoading({ timeLoading: 1500 });
};
return <button onClick={handleShowLoading}>Mostrar Loading</button>;
};
export default App;
Ejemplo Práctico en Next.js
"use client";
import { useState } from "react";
import { getSimpson } from "../actions/getSimpson";
import Image from "next/image";
import { showLoading, hideLoading } from "loading-request";
import "loading-request/dist/index.css";
export default function ApiSimpson() {
const [data, setData] = useState(null);
const handleGetSimpson = async () => {
showLoading({ message: "Cargando API..." });
try {
const data = await getSimpson();
setData(data);
} catch (error) {
console.error("Error al obtener los datos:", error);
} finally {
hideLoading();
}
};
return (
<>
<button className="my-4" onClick={handleGetSimpson}>
Obtener personajes
</button>
{data && (
<div className="cards">
{data.map((personaje, index) => (
<div key={index} className="card">
<div>{personaje.character}</div>
<Image width={200} height={200} src={personaje.image} alt={personaje.character} />
</div>
))}
</div>
)}
</>
);
}
Mostrando Resultados de una API REST en Next.js
👉 Código
Ejemplo Práctico en Svelte.js
<script>
import svelteLogo from "./assets/svelte.svg";
// Importando el paquete loading-request
import { showLoading, hideLoading } from "loading-request";
import "loading-request/dist/index.css";
let personas = null;
async function fetchPersonas() {s
showLoading({
message: "Cargando Solicitud...",
spinnerColor: "#f3752b",
textLoadingColor: "#EE5E09",
});
try {
const URL = "https://reqres.in/api/users?page=1";
const response = await fetch(URL);
if (!response.ok) {
throw new Error('Error en la solicitud');
}
personas = await response.json();
} catch (err) {
console.log('Error al cargar la API:', err.message);
} finally {
hideLoading();
}
}
</script>
<main>
<h1>
<button on:click={fetchPersonas}> Cargar API</button>
<img src={svelteLogo} class="logo svelte" alt="Svelte Logo" />
</h1>
{#if personas}
<ul class="user-list">
{#each personas.data as persona (persona.id)}
<li class="user-item">
<img
src={persona.avatar}
alt={persona.first_name}
class="user-avatar"
/>
<div class="user-details">
<p class="user-details__name">
Nombre: {persona.first_name}
</p>
<p class="user-details__email">Email: {persona.email}</p>
</div>
</li>
{/each}
</ul>
{/if}
</main>
Mostrando Resultado final
👉 Código
Ejemplo Práctico en Vue.js
<script setup>
import { showLoading, hideLoading } from "loading-request";
import "loading-request/dist/index.css";
const handleShowLoading = () => {
showLoading({
message: "Cargando App...",
spinnerColor: "#f3752b",
textLoadingColor: "#EE5E09",
});
hideLoading({ timeLoading: 1000 });
};
</script>
<template>
<div id="app">
<button @click="handleShowLoading">Mostrar Loading</button>
</div>
</template>
API
showLoading(opciones?: ShowLoadingOptions)
Es una función que permite mostrar un indicador de carga con opciones personalizables.
-
Opciones:
- message: Mensaje que se muestra junto al indicador de carga. Por defecto es "Cargando...".
- spinnerColor: Color opcional del borde del spinner. Si se proporciona, se aplica dinámicamente.
- textLoadingColor: Color opcional del texto del mensaje de carga. Si se proporciona, se aplica dinámicamente.
Recibe un objeto de configuración opcional. Si no se proporciona ningún argumento, se utilizará un objeto vacío como valor por defecto.
Ejemplo de uso:
showLoading({
message: "Cargando...",
spinnerColor: "#f3752b",
textLoadingColor: "#EE5E09",
});
hideLoading(opciones?: HideLoadingOptions)
Es una función que permite ocultar el indicador de carga después de un período de tiempo especificado.
-
Parámetros:
- opciones: Un objeto opcional que puede contener:
- timeLoading: Tiempo en milisegundos antes de ocultar el indicador. Por defecto es 500ms.
Si se llama sin argumentos, se utilizará un objeto vacío como valor por defecto.
Ejemplo de uso:
hideLoading({ timeLoading: 1500 });
Contribuir
Si encuentras algún problema o tienes una idea para mejorar el paquete, por favor abre un issue o envía un pull request en GitHub: https://github.com/urian121/loading-request
Desarrollado por
Agradecimientos
¡Gracias a todos los Devs 👨💻 que han utilizado y contribuido al desarrollo de Loading Request! Su apoyo y retroalimentación son fundamentales para mejorar continuamente este paquete.
This content originally appeared on DEV Community and was authored by URIAN VIERA

URIAN VIERA | Sciencx (2024-07-09T14:18:20+00:00) Mejora la Experiencia del Usuario con Loading Request. Retrieved from https://www.scien.cx/2024/07/09/mejora-la-experiencia-del-usuario-con-loading-request/
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.