Saltar al contenido principal

Estructura de página

Organiza el documento en partes lógicas, indicando el tipo de contenido de cada sección con la ayuda de los elementos estructurales de HTML.

Al identificar cada sección de una página con la etiqueta adecuada, estamos ofreciendo puntos de referencia que facilitan la navegación a las tecnologías asistivas.

Cabecera

La cabecera de una página se representa mediante el elemento header.

El elemento header define un punto de referencia del tipo banner. Este tipo de contenido se sitúa generalmente al principio de la página y está orientado al sitio web en general.

HTML
<header>
...
</header>

Ejemplos del contenido de tipo banner son el logo, la navegación principal o un buscador.

Nota: Cuando el elemento header está dentro de otro elemento estructural como article, aside, main, nav o section, no se considera como banner.

El elemento nav representa una sección con enlaces de navegación. Define un punto de referencia navigation.

HTML
<nav>
    <ul>
        <li><a href="#">Inicio</a></li>
        <li><a href="#">Servicios</a></li>
        <li><a href="#">Contacto</a></li>
    </ul>
</nav>

Es importante que los elementos de una página sigan el orden lógico de lectura, es decir, el menú de navegación debería estar al principio del documento.

Después podemos cambiar visualmente su ubicación mediante CSS, pero para el usuario con un lector de pantalla aparecerá en el orden adecuado.

Contenido principal

Identificamos el contenido principal de un documento con el elemento main. Este es el contenido único de cada página, a diferencia de otras secciones como la cabecera o el pie de página que suelen repetirse.

HTML
<main>
...
</main>

Contenido complementario

Se considera contenido complementario cualquier información relacionada con el contenido principal, por ejemplo, la biografía del autor de un artículo, o un grupo de artículos relacionados.

Se representa con el elemento aside y define un punto de referencia del tipo complementary.

HTML
<aside>
    <h3>Artículos relacionados</h3>
    ...
</aside>

Secciones

El elemento section sirve para agrupar contenido relativo a un mismo tema. Normalmente cada sección se identifica con un encabezado (h1- h6).

HTML
<section>
    <h1>Noticias internacionales</h1>
    <p>...</p>
</section>

Nota: No hay que utilizar section como contenedor genérico. Para agrupar contenidos con el objetivo de darles estilo, hay que utilizar el elemento div.

Artículos

El elemento article identifica contenido de un sitio web que puede ser publicado o distribuido de forma independiente. Este contenido puede ser, por ejemplo, un artículo de un blog o un producto de una tienda online.

El elemento article puede contener a su vez otros elementos estructurales como header o footer e incluso diferentes secciones (section).

HTML
<article>
    <h2>Título del artículo</h2>
    <p>...</p>
    <footer>
        <p>Publicado el <time datetime="2016-11-03 11:00">03 de Noviembre</time> por John Doe</p>
    </footer>
</article>

Búsqueda

Un punto de referencia de búsqueda se define usando el rol search (no existe etiqueta HTML para este rol).

HTML
<form role="search">
    <input type="search" aria-label="Buscar">
    <button type="submit">Buscar</button>
</form>

Pie de página

Para representar el pie de página usamos el elemento footer.

El elemento footer define un punto de referencia del tipo contentinfo, siempre que descienda directamente del elemento body.

HTML
<footer>
    <p>&copy; 2016 Nombre empresa</p>
</footer>

El rol contentinfo indica que se trata de información sobre el sitio web, como el copyright o enlaces a políticas de privacidad.

Ejemplo de estructura de página

Aquí tenemos un ejemplo de una página utilizando elementos de HTML estructurales.

HTML
<header>
    <nav>
    ...
    </nav>
</header>

<main>
    <article>
    ...
    </article>

    <aside>
    ...
    </aside>
</main>

<footer>
...
</footer>

Pautas de Accesibilidad 1.3: (Perceptible) y 2.4 (Navegable), criterios de conformidad 1.3.1, 1.3.6 y 2.4.1.