Curso gratuito de HTML. Regístrate para hacer un seguimiento de tu progreso →

HTML: Web Semántico

Con el aumento de la cantidad de páginas en Internet, surgió el problema de leer la información no solo por humanos, sino también por robots. Mientras que los humanos separan los bloques de significado entre sí, ven la disposición y pueden encontrar rápidamente la sección de la página que les interesa, los robots ven toda la página como texto y no pueden dividirla por sí mismos para analizar el significado de la información.

Este problema se hizo evidente a principios del nuevo milenio, cuando la cantidad de páginas en Internet comenzó a crecer constantemente y los motores de búsqueda (Google, Bing, Yandex, Yahoo) tenían capacidades limitadas para analizar correctamente cada página en Internet. Por esta razón, los webmasters especificaban intencionalmente palabras clave populares en ese momento en sus sitios para mejorar su posición en los resultados de búsqueda.

Ahora existen formas de mostrar el significado (semántica) de una página HTML a los robots. Gracias a esto, al realizar una búsqueda en un motor de búsqueda, se puede ver no solo una lista de enlaces a sitios web, sino también información específica, como una receta de pastel, una ruta a una calle específica o los contactos de una organización.

La semántica correcta también permite que los dispositivos interpreten correctamente las partes de un sitio web. Por ejemplo, el modo de lectura en los teléfonos móviles intenta eliminar los bloques no relacionados con el contenido para dejar solo la parte significativa.

Vista estándar de una lección en Code Basics y vista en modo de lectura

Hay dos implementaciones del web semántico:

  • Basado en microdatos. Estos son atributos especiales que se agregan a la estructura HTML y ayudan a los robots a encontrar la información relevante. Los microdatos se utilizan con mayor frecuencia debido a sus numerosas posibilidades y campos para la marcación.

  • Utilizando el estándar HTML5. El estándar ha introducido una serie de etiquetas que ayudan a los robots a analizar la información, encontrar relaciones lógicas entre los bloques (o comprender que no existen) y buscar las partes necesarias para una visualización correcta en dispositivos de lectura.

Aunque el estándar HTML5 no ha reemplazado por completo los microdatos debido a sus capacidades más limitadas, su uso junto con los microdatos permite que los robots procesen el sitio de manera más precisa y encuentren bloques lógicos en él.

Ejemplo de marcado semántico en HTML5

<main> <!-- Definición de la parte principal de la página -->
  <article> <!-- Definición de un artículo -->
    <header> <!-- Información de encabezado del artículo -->
      <h1>Título del artículo</h1>
      <img src="article.png" alt="Título del artículo">
    </header>

    <p>Texto de nuestro artículo</p>

    <footer> <!-- "Pie de página del artículo" con información del autor y fecha -->
      <address> <!-- Información del autor del artículo -->
        <p>Autor: Dmitry</p>
        <p>Email: dmitry@test.test</p>
      </address>
      <time datetime="2019-07-27">27 de julio</time> <!-- Fecha de escritura del artículo -->
    </footer>
  </article>
</main>

Tarea

Crea el marcado de un artículo como se muestra en el ejemplo anterior. Los datos dentro del marcado pueden ser arbitrarios.

¿El ejercicio no pasa la prueba, qué debo hacer? 😶

Si te quedaste atascado, es el momento perfecto para hacer una pregunta en las "Discusiones".
* Asegúrate de incluir la salida de las pruebas. Sin ella, es casi imposible entender qué está mal, incluso si muestras tu código. Los programadores tienen dificultades para ejecutar el código en su mente, pero casi siempre es posible entender a dónde mirar a partir del error que recibiste.

Mi código funciona en mi entorno, pero no aquí 🤨

Las pruebas están diseñadas de manera que verifican la solución de diferentes maneras y con diferentes datos. A menudo, una solución funciona con ciertos datos de entrada pero no con otros. Para entender este punto, revisa la pestaña "Pruebas" y presta atención a los mensajes de error, que suelen contener pistas.

Mi código es diferente a la solución del profesor 🤔

Esto es normal 🙆. En programación, una tarea puede tener muchas soluciones diferentes. Si tu código pasa la prueba, cumple con los requisitos de la tarea.

En raras ocasiones, la solución puede estar ajustada para pasar las pruebas, pero esto suele ser evidente.

Leí la lección, pero no entendí nada 🙄

Crear materiales de aprendizaje comprensibles para todos es bastante difícil. Hacemos nuestro mejor esfuerzo, pero siempre hay margen para mejorar. Si encuentras material que no entiendes, describe el problema en las "Discusiones". Es ideal si puedes formular los aspectos que no entiendes en forma de preguntas. Por lo general, necesitamos unos días para hacer mejoras.

Por cierto, tú también puedes contribuir a mejorar los cursos: en la parte inferior hay un enlace al código fuente de las lecciones, que se puede modificar directamente en el navegador.


¿Encontraste un error? ¿Quieres añadir algo? Las solicitudes de extracción son bienvenidas. https://codica.la/errores
Si te encuentras con dificultades y no sabes qué hacer, pregunta en nuestra gran y amigable comunidad