Un menú acordeón es un componente de interfaz que permite mostrar y ocultar contenido en secciones desplegables, organizadas de manera vertical. Cada sección (o ítem) se puede expandir o colapsar para revelar contenido adicional, y en muchos casos, al abrir una sección, las demás se cierran automáticamente para mantener el diseño limpio.
Usos en una interfaz web:
Organización: Perfecto para mostrar gran cantidad de contenido en un espacio reducido.
Jerarquía: Útil para estructurar secciones relacionadas, como preguntas frecuentes (FAQs), menús secundarios o configuraciones de usuario.
Interactividad: Mejora la experiencia del usuario al proporcionar una navegación intuitiva y ordenada.
Cuándo aplicarlo:
– Cuando tienes múltiples secciones que no necesitan estar visibles al mismo tiempo.
– En menús laterales de navegación para mantener la página compacta.
– Para desplegar configuraciones avanzadas o detalles específicos bajo demanda.
Menú acordeón con Bootstrap: Código completo
A continuación te voy a hacer una propuesta de este tipo de menús, que puede ser incluido directamente en tu sitio web sin apenas cambios. Aquí tenéis el código fuente
1. HTML5
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Menú Acordeón Profesional</title>
<!-- Bootstrap CSS -->
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/css/bootstrap.min.css" rel="stylesheet">
<link rel="stylesheet" href="styles.css">
</head>
<body>
<div class="container my-5">
<h2 class="text-center mb-4">Menú Acordeón Profesional</h2>
<div class="accordion" id="accordionExample">
<!-- Item 1 -->
<div class="accordion-item">
<h2 class="accordion-header" id="headingOne">
<button class="accordion-button" type="button" data-bs-toggle="collapse" data-bs-target="#collapseOne" aria-expanded="true" aria-controls="collapseOne">
Sección 1: Introducción
</button>
</h2>
<div id="collapseOne" class="accordion-collapse collapse show" aria-labelledby="headingOne" data-bs-parent="#accordionExample">
<div class="accordion-body">
Esta es la primera sección del menú acordeón. Puedes usar esta área para explicar conceptos básicos.
</div>
</div>
</div>
<!-- Item 2 -->
<div class="accordion-item">
<h2 class="accordion-header" id="headingTwo">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo">
Sección 2: Detalles
</button>
</h2>
<div id="collapseTwo" class="accordion-collapse collapse" aria-labelledby="headingTwo" data-bs-parent="#accordionExample">
<div class="accordion-body">
En esta sección puedes añadir información más detallada o avanzada.
</div>
</div>
</div>
<!-- Item 3 -->
<div class="accordion-item">
<h2 class="accordion-header" id="headingThree">
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#collapseThree" aria-expanded="false" aria-controls="collapseThree">
Sección 3: Conclusión
</button>
</h2>
<div id="collapseThree" class="accordion-collapse collapse" aria-labelledby="headingThree" data-bs-parent="#accordionExample">
<div class="accordion-body">
Usa esta sección para añadir conclusiones o llamados a la acción.
</div>
</div>
</div>
</div>
</div>
<!-- Bootstrap JS Bundle -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha3/dist/js/bootstrap.bundle.min.js"></script>
<script src="script.js"></script>
</body>
</html>
2. CSS3
/* General Styles */
body {
font-family: 'Poppins', sans-serif;
background-color: #f4f4f9;
color: #333;
margin: 0;
padding: 0;
}
.container {
max-width: 800px;
margin: 2rem auto;
padding: 0 1rem;
}
h2 {
font-weight: bold;
color: #2c3e50;
text-align: center;
margin-bottom: 2rem;
}
/* Accordion Styles */
.accordion-item {
border: none;
margin-bottom: 10px;
border-radius: 10px;
overflow: hidden;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.accordion-header {
margin: 0;
}
.accordion-button {
background-color: #3498db;
color: #fff;
font-size: 1.2rem;
font-weight: 500;
padding: 15px;
border: none;
text-align: left;
border-radius: 0;
transition: background-color 0.3s ease, box-shadow 0.3s ease;
}
.accordion-button:hover {
background-color: #2980b9;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
}
.accordion-button:not(.collapsed) {
background-color: #1e6f9f;
color: #fff;
box-shadow: inset 0 -3px 5px rgba(0, 0, 0, 0.2);
}
.accordion-body {
font-size: 1rem;
background-color: #ecf0f1;
color: #2c3e50;
padding: 20px;
line-height: 1.6;
border-top: 3px solid #3498db;
}
/* Responsive Design */
@media (max-width: 768px) {
h2 {
font-size: 1.5rem;
}
.accordion-button {
font-size: 1rem;
padding: 12px;
}
.accordion-body {
font-size: 0.9rem;
padding: 15px;
}
}
@media (max-width: 576px) {
.container {
padding: 0 0.5rem;
}
h2 {
font-size: 1.3rem;
margin-bottom: 1.5rem;
}
}
3. Javascript
// script.js
document.addEventListener("DOMContentLoaded", () => {
const accordionItems = document.querySelectorAll(".accordion-button");
accordionItems.forEach((item) => {
item.addEventListener("click", () => {
console.log(`Sección "${item.innerText}" seleccionada.`);
});
});
});
Explicación del código
HTML: Estructura del acordeón
<div class="accordion">
: Contenedor principal del acordeón.
<div class="accordion-item">
: Cada ítem individual.
<button class="accordion-button"
: El botón interactivo que permite expandir o colapsar contenido.
– data-bs-toggle
: Indica a Bootstrap que este botón controla una sección colapsable.
– data-bs-target
: Identifica el contenido que debe abrirse.
<div class="accordion-collapse collapse">
: Contenedor del contenido desplegable. La clase collapse
lo oculta inicialmente.
CSS: Diseño profesional
Colores:
-Paleta profesional basada en tonos de azul y gris (#3498db
, #2c3e50
, y #ecf0f1
).
-Los colores tienen un contraste adecuado para garantizar accesibilidad.
Sombras y Bordes:
-Sombras suaves en cada ítem del acordeón (box-shadow
) para dar una apariencia flotante.
-Bordes redondeados (border-radius
) para un look moderno.
Transiciones:
–transition
para hacer que los cambios de color y sombra sean suaves y visualmente agradables.
Espaciado:
-Amplio espacio en el padding en los botones y el contenido para una mejor legibilidad.
Responsividad:
-Optimizado el tamaño de fuente y los márgenes para dispositivos móviles (max-width: 768px
y max-width: 576px
).
-El diseño se adapta perfectamente en diferentes pantallas, asegurando una buena experiencia en móviles y tablets.
JavaScript:
Personalización
-Añadimos eventos para registrar en la consola qué sección se seleccionó. Este es solo un ejemplo; puedes usarlo para cualquier funcionalidad adicional.
Con este diseño tienes un menú acordeón profesional, claro, funcional y estéticamente atractivo, ideal para mejorar la experiencia del usuario en tu sitio web.