• +34 685 967 885
  • +34 695 898 191
  • antgarprats@gmail.com
  • Antonio García Prats

menú acordeón

Menú acordeón

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 menú acordeón 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 del menú acordeón

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.

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *