• +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 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.

    Deja una respuesta

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