Primeros pasos con HTML

En este artículo, cubrimos los conceptos básicos de HTML. Para empezar, este artículo define elementos, atributos y todos los demás términos importantes que puedas haber escuchado. También explica dónde encajan en HTML. Aprenderás cómo se estructuran los elementos HTML, cómo se estructura una página HTML típica y otras características importantes del lenguaje básico. ¡En el camino, también tendrás la oportunidad de jugar con HTML!

Requisitos previos: Conocimientos informáticos básicos, software básico instalado, y conocimientos básicos de trabajar con archivos.
Objetivo: Para obtener una familiaridad básica con HTML y practicar la escritura de algunos elementos HTML

¿Qué es HTML?

HTML (HyperText Markup Language, por sus siglas en inglés) es un lenguaje de marcado que indica a los navegadores web cómo estructurar las páginas web que visita. Puede ser tan complicado o tan simple como el desarrollador web quiera que sea. HTML consiste en una serie de elementos, que utiliza para encerrar, envolver o marcar diferentes partes del contenido para que aparezca o actúe de cierta manera. Las etiquetas pueden convertir el contenido en un hipervínculo para conectarse a otra página, poner palabras en cursiva, etc. Por ejemplo, considere la siguiente línea de texto:

Mi gato es muy gruñón

Si quisiéramos que el texto se mantuviera solo, podríamos especificar que es un párrafo encerrándolo en un elemento de párrafo (<p>):

html
<p>Mi gato es muy gruñón</p>

Nota: Las etiquetas en HTML no distinguen entre mayúsculas y minúsculas. Esto significa que se pueden escribir en mayúsculas o minúsculas. Por ejemplo, una etiqueta <title> podría escribirse como <title>, <TITLE>, <Title>, <TiTlE>, etc., y funcionará. Sin embargo, es una buena práctica escribir todas las etiquetas en minúsculas para mayor coherencia y legibilidad.

Anatomía de un elemento HTML

Exploremos más a fondo nuestro elemento de párrafo de la sección anterior:

Un fragmento de código de ejemplo que demuestra la estructura de un elemento html.<p> Mi gato es muy gruñón</p>.

La anatomía de nuestro elemento es:

  • La etiqueta de apertura: Consiste en el nombre del elemento (en este ejemplo, p para el párrafo), envuelto en corchetes angulares de apertura y cierre. Esta etiqueta de apertura marca dónde inicia o comienza a surtir efecto el elemento. En este ejemplo, precede al inicio del texto del párrafo.
  • El contenido: Este es el contenido del elemento. En este ejemplo, es el texto del párrafo.
  • La etiqueta de cierre: Esta es la misma que la etiqueta de apertura, excepto que incluye una barra diagonal delante del nombre del elemento. Esto marca donde termina el elemento. No incluir una etiqueta de cierre es un error común para principiantes que puede producir resultados peculiares.

El elemento es la etiqueta de apertura, seguida del contenido, seguida de la etiqueta de cierre.

Aprendizaje activo: crear tu primer elemento HTML

Edite la siguiente línea en el área "Código editable" envolviéndola con las etiquetas <em> y </em>. Para abrir el elemento, coloque la etiqueta de apertura <em> al comienzo de la línea. Para cerrar el elemento, coloque la etiqueta de cierre </em> al final de la línea. ¡Hacer esto debería darle formato de texto en cursiva a la línea! Consulta la actualización de tus cambios en vivo en el área deSalida en vivo.

Si comete un error, puede borrar su trabajo utilizando el botónRestablecer. Si te quedas realmente atascado, pulsa el botónMostrar solución para ver la respuesta.

Anidando elementos

Los elementos se pueden colocar dentro de otros elementos. Esto se llama anidamiento. Si quisiéramos decir que nuestro gato está muy gruñón, podríamos envolver la palabra muy en un elemento <strong>, lo que significa que la palabra debe tener un formato de texto fuerte:

html
<p>Mi gato es <strong>muy</strong> gruñón.</p>

Hay una forma correcta e incorrecta de anidar. En el ejemplo anterior, abrimos primero el elemento p, luego abrimos el elemento strong. Para una anidación adecuada, primero debemos cerrar el elemento strong, antes de cerrar p.

El siguiente es un ejemplo de la forma incorrecta de anidar:

html
<p>Mi gato es <strong>muy gruñón.</p></strong>

Las etiquetas tienen que abrirse y cerrarse de manera que estén dentro o fuera la una de la otra. Con el tipo de superposición en el ejemplo anterior, el navegador tiene que adivinar tu intención. Este tipo de adivinanzas puede dar lugar a resultados inesperados.

Elementos vacíos

No todos los elementos siguen el patrón de una etiqueta de apertura, contenido y una etiqueta de cierre. Algunos elementos consisten en una sola etiqueta, que normalmente se utiliza para insertar/incrustar algo en el documento. Dichos elementos se denominan elementos vacíos. Por ejemplo, el elemento <img> incrusta un archivo de imagen en una página:

html
<img
  src="https://raw.githubusercontent.com/mdn/beginner-html-site/gh-pages/images/firefox-icon.png"
  alt="Icono de Firefox" />

Esto daría como resultado lo siguiente:

Nota: En HTML, no es necesario añadir un / al final de la etiqueta de un elemento vacío, por ejemplo: <img src="images/cat.jpg" alt="cat" />. Sin embargo, también es una sintaxis válida, y puede hacerlo cuando desee que su HTML sea XML válido.

Atributos

Los elementos también pueden tener atributos. Los atributos se ven así:

etiqueta de párrafo con el atributo 'class="editor-note"' enfatizado

Los atributos contienen información adicional sobre el elemento que no aparecerá en el contenido. En este ejemplo, el atributo class es un nombre de identificación utilizado para identificar el elemento con información de estilo.

Un atributo debe tener:

  • Un espacio entre él y el nombre del elemento. (Para un elemento con más de un atributo, los atributos también deben estar separados por espacios).
  • El nombre del atributo, seguido de un signo igual.
  • Un valor de atributo, envuelto con comillas de apertura y cierre.

Aprendizaje activo: añadir atributos a un elemento

El elemento <img> puede tomar una serie de atributos, que incluyen:

src

El atributo src es un atributo requerido que especifica la ubicación de la imagen. Por ejemplo: src="https://raw.githubusercontent.com/mdn/beginner-html-site/gh-pages/images/firefox-icon.png".

alt

El atributo alt especifica una descripción de texto de la imagen. Por ejemplo: alt="El icono de Firefox".

width

El atributo width especifica el ancho de la imagen con la unidad en píxeles. Por ejemplo: width="300".

height

El atributo height especifica la altura de la imagen con la unidad en píxeles. Por ejemplo: height="300".

Edita la siguiente línea en el área del Input para convertirla en una imagen.

  1. Encuentra tu imagen favorita en línea, haz clic con el botón derecho y pulsa Copiar enlace/dirección de imagen.
  2. De vuelta en el área de abajo, añade el atributo src y rellénalo con el enlace del paso 1.
  3. Establece el atributo alt.
  4. Añade los atributos width y height.

Podrás ver los cambios en vivo en el área de Salida.

Si comete un error, siempre puede restablecerlo utilizando el botón Restablecer. Si te quedas realmente atascado, pulsa el botón Mostrar solución para ver la respuesta.

Atributos booleanos

A veces verás atributos escritos sin valores. Esto es totalmente aceptable. Estos se llaman atributos booleanos. Los atributos booleanos solo pueden tener un valor, que generalmente es el mismo que el nombre del atributo. Por ejemplo, considere el atributo disabled, que puede asignar a los elementos de entrada de formulario. (Utiliza esto para deshabilitar los elementos de entrada del formulario para que el usuario no pueda realizar entradas. Los elementos deshabilitados suelen tener un aspecto grisáceo.) Por ejemplo:

html
<input type="text" disabled="disabled" />

Como abreviatura, es aceptable escribir esto de la siguiente manera:

html
<!-- el uso del atributo deshabilitado impide que el usuario final introduzca texto en el cuadro de entrada -->
<input type="text" disabled />

<!-- se permite la entrada de texto, ya que no contiene el atributo deshabilitado -->
<input type="text" />

Como referencia, el ejemplo anterior también incluye un elemento de entrada de formulario no deshabilitado. El HTML del ejemplo anterior produce este resultado:

Omitir comillas en torno a los valores de atributo

Si observa el código de muchos otros sitios, es posible que encuentre una serie de estilos de marcado extraños, incluidos los valores de atributos sin comillas. Esto está permitido en ciertas circunstancias, pero también puede romper su margen de beneficio en otras circunstancias. El elemento en el fragmento de código a continuación, <a>, se llama ancla. Los anclajes encierran texto y los convierten en enlaces. El atributo href especifica la dirección web a la que apunta el enlace. Puedes escribir esta versión básica a continuación con solo el atributo href, así:

html
<a href=https://www.mozilla.org/>sitio web favorito</a>

Los anclajes también pueden tener un atributo title, una descripción de la página vinculada. Sin embargo, tan pronto como añadimos el title de la misma manera que el atributo href hay problemas:

html
<a href=https://www.mozilla.org/ title=Pagina de Mozilla>sitio web favorito</a>

Como se ha escrito anteriormente, el navegador malinterpreta el marcado, confundiendo el atributo title con tres atributos: un atributo title con el valor The, y dos atributos booleanos, Mozilla y homepage. ¡Obviamente, esto no es la intención! Causará errores o comportamientos inesperados, como puede ver en el ejemplo en vivo a continuación. ¡Intenta pasar el cursor sobre el enlace para ver el texto del título!

Incluya siempre las comillas de los atributos. Evita tales problemas y da como resultado un código más legible.

¿Comillas simples o dobles?

En este artículo, también notarás que los atributos están entre comillas dobles. Sin embargo, es posible que veas comillas simples en algún código HTML. Es una cuestión de estilo. Puedes elegir libremente cuál prefieres. Ambas opciones son equivalentes:

html
<a href='https://www.example.com'>Un enlace a mi ejemplo.</a>

<a href="https://www.example.com">Un enlace a mi ejemplo.</a>

Asegúrate de no mezclar comillas simples y comillas dobles. Este ejemplo (a continuación) muestra una especie de mezcla de comillas que saldrá mal:

html
<a href="https://www.example.com'>Un enlace a mi ejemplo.</a>

Sin embargo, si utilizas un tipo de comilla, puedes incluir el otro tipo de comilla dentro tus valores de atributo:

html
<a href="https://www.example.com" title="¿No es 'esto' divertido?">
  Un enlace a mi ejemplo.
</a>

Para usar comillas dentro de otras comillas del mismo tipo (comillas simples o comillas dobles), use entidades HTML. Por ejemplo, esto se romperá:

html
<a href="https://www.example.com" title="Una referencia "interesante"">Un enlace a mi ejemplo.</a>

En su lugar, debe hacer lo siguiente:

html
<a href="https://www.example.com" title="Una referencia &quot;interesante&quot;">Un enlace a mi ejemplo.</a>

Anatomía de un documento HTML

Los elementos HTML individualmente no son muy útiles por sí solos. A continuación, examinemos cómo se combinan los elementos para formar una página HTML completa:

html
<!doctype html>
<html lang="es">
  <head>
    <meta charset="utf-8" />
    <title>Mi página de prueba</title>
  </head>
  <body>
    <p>Esta es mi página</p>
  </body>
</html>

Aquí tenemos:

  1. <!DOCTYPE html>: El tipo de documento. Cuando HTML era joven (1991-1992), los doctype estaban destinados a actuar como enlaces a un conjunto de reglas que la página HTML tenía que seguir para ser considerada un buen HTML. Los doctypes solían parecerse a algo como esto:
    html
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    
    Más recientemente, el doctype es un artefacto histórico que debe incluirse para que todo lo demás funcione correctamente. <!DOCTYPE html> es la cadena más corta de caracteres que cuenta como un tipo de documento válido. ¡Eso es todo lo que necesitas saber!
  2. <html></html>: El elemento <html>. Este elemento envuelve todo el contenido de la página. A veces se le conoce como el elemento raíz.
  3. <head></head>: El elemento <head>. Este elemento actúa como un contenedor para todo lo que desea incluir en la página HTML, que no es el contenido que la página mostrará a los espectadores. Esto incluye palabras clave y una descripción de la página que aparecería en los resultados de búsqueda, CSS para dar estilo al contenido, declaraciones de conjuntos de caracteres y más. Aprenderás más sobre esto en el próximo artículo de la serie.
  4. <meta charset="utf-8">: El elemento <meta>. Este elemento representa metadatos que no pueden ser representados por otros elementos HTML relacionados con metadatos, como <base>, <link>, <script> (en-US), <style> o <title>. El atributo charset especifica la codificación de caracteres para su documento como UTF-8, que incluye la mayoría de los caracteres de la gran mayoría de los lenguajes humanos escritos. Con esta configuración, la página ahora puede manejar cualquier contenido textual que pueda contener. No hay razón para no configurar esto, y puede ayudar a evitar algunos problemas más adelante.
  5. <title></title>: El elemento <title>. Esto establece el título de la página, que es el título que aparece en la pestaña del navegador en la que se carga la página. El título de la página también se utiliza para describir la página cuando está en marcadores.
  6. <body></body>: El elemento <body>. Contiene todo el contenido que se muestra en la página, incluidos texto, imágenes, vídeos, juegos, pistas de audio reproducibles o cualquier otra cosa.

Aprendizaje activo: añadir algunas funciones a un documento HTML

Si quieres experimentar con escribir algo de HTML en tu ordenador local, puedes:

  1. Copie el ejemplo de página HTML listado anteriormente.
  2. Crea un nuevo archivo en tu editor de texto.
  3. Pega el código en el nuevo archivo de texto.
  4. Guarde el archivo como index.html.

Nota: También puedes encontrar esta plantilla HTML básica en el repositorio de GitHub del área de aprendizaje de MDN.

Ahora puede abrir este archivo en un navegador web para ver cómo se ve el código renderizado. Edita el código y actualiza el navegador para ver cuál es el resultado. Inicialmente, la página se ve así:

Una simple página HTML que dice Esta es mi páginaEn este ejercicio, puedes editar el código localmente en tu ordenador, como se describió anteriormente, o puedes editarlo en la ventana de muestra a continuación (la ventana de muestra editable representa solo el contenido del elemento <body>, en este caso). Mejora tus habilidades implementando las siguientes tareas:

  • Justo debajo de la etiqueta de apertura del elemento <body>, añade un título principal para el documento. Esto debe envolverse dentro de una etiqueta <h1> de apertura y </h1> de cierre.
  • Edita el contenido del párrafo para incluir texto sobre un tema que te parezca interesante.
  • Haz que las palabras importantes se destaquen en negrita envolviéndolas dentro de una etiqueta <strong> de apertura y </strong> de cierre.
  • Añade un enlace a tu párrafo, como se explicó anteriormente en el artículo.
  • Añade una imagen a tu documento. Colócalo debajo del párrafo, como se explicó anteriormente en el artículo. Gana puntos de bonificación si consigues vincular a una imagen diferente (ya sea localmente en tu ordenador o en algún otro lugar de la web).

Si comete un error, siempre puede restablecerlo utilizando el botón Restablecer. Si te quedas realmente atascado, pulsa el botón Mostrar solución para ver la respuesta.

Espacios en blanco en HTML

En los ejemplos anteriores, es posible que hayas notado que se incluyen muchos espacios en blanco en el código. Este paso es opcional. Estos dos fragmentos de código son equivalentes:

html
<p id="noWhitespace">Los perros son tontos.</p>

<p id="whitespace">Los perros
    son
        tontos.</p>

No importa cuánto espacio en blanco utilice dentro del contenido del elemento HTML (que puede incluir uno o más caracteres de espacio, o también saltos de línea), el analizador HTML reduce cada secuencia de espacio en blanco a un solo espacio al representar el código. Entonces, ¿por qué usar tanto espacio en blanco? La respuesta es la legibilidad.

Puede ser más fácil entender lo que está pasando en tu código si lo tienes bien formateado. En nuestro HTML tenemos cada elemento anidado indentado por dos espacios más que el que está dentro. Depende de usted elegir el estilo de formato (cuántos espacios para cada nivel de indentación, por ejemplo), pero debe considerar formatearlo.

Echemos un vistazo a cómo el navegador representa los dos párrafos anteriores con y sin espacios en blanco:

Nota: El acceso a innerHTML de los elementos de JavaScript mantendrá intacto todo el espacio en blanco. Esto puede arrojar resultados inesperados si el navegador recorta el espacio en blanco.

js
const noWhitespace = document.getElementById("noWhitespace").innerHTML;
console.log(noWhitespace);
// "Los perros son tontos".

const whitespace = document.getElementById("whitespace").innerHTML;
console.log(whitespace);
// "Los perros
//    son
//        tontos."

Referencias de entidades: Incluir caracteres especiales en HTML

En HTML, los caracteres <, >, ", ' y & son caracteres especiales. Son partes de la sintaxis HTML en sí. Entonces, ¿cómo incluyes uno de estos caracteres especiales en tu texto? Por ejemplo, si desea usar un signo ampersand (&) o menor que, y no interpretarlo como código.

Haces esto con referencias de caracteres. Estos son códigos especiales que representan caracteres, para ser utilizados en estas circunstancias exactas. Cada referencia de carácter comienza con un ampersand (&) y termina con un punto y coma (;).

Carácter literal Referencia de carácter equivalente
< &lt;
> &gt;
" &quot;
' &apos;
& &amp;

El equivalente de referencia de carácter podría recordarse fácilmente porque el texto que utiliza puede verse como menor que (less than, en inglés) para '&lt;', comilla (quot, en inglés) para '&quot;' y de manera similar para otros. Para obtener más información sobre las referencias de entidades, consulta Lista de referencias de entidades de caracteres XML y HTML (Wikipedia).

En el siguiente ejemplo, hay dos párrafos:

html
<p>En HTML, se define un párrafo utilizando el elemento <p>.</p>

<p>En HTML, se define un párrafo utilizando el elemento &lt;p&gt;.</p>

En la salida en vivo a continuación, puede ver que el primer párrafo ha salido mal. El navegador interpreta la segunda instancia de <p> como comenzar un nuevo párrafo. El segundo párrafo se ve bien porque tiene corchetes angulares con referencias de caracteres.

Nota: No es necesario usar referencias de entidad para ningún otro símbolo, ya que los navegadores modernos manejarán bien los símbolos reales siempre que la codificación de caracteres de tu HTML esté configurada en UTF-8.

Comentarios en HTML

HTML tiene un mecanismo para escribir comentarios en el código. Los navegadores ignoran los comentarios, lo que hace que los comentarios sean invisibles para el usuario. El propósito de los comentarios es permitirle incluir notas en el código para explicar su lógica o codificación. Esto es muy útil si vuelve a una base de código después de estar ausente el tiempo suficiente para no recordarlo por completo. Del mismo modo, los comentarios son invaluables ya que diferentes personas están haciendo cambios y actualizaciones.

Para escribir un comentario en HTML, envuélvalo en los marcadores especiales <!-- y -->. Por ejemplo:

html
<p>No estoy dentro de un comentario</p>

<!-- <p>¡Yo si estoy!</p> -->

Como puede ver a continuación, solo se muestra el primer párrafo en la salida en vivo.

Resumen

¡Has llegado al final del artículo! Esperamos que hayas disfrutado de tu recorrido por los conceptos básicos de HTML.

En este punto, debes entender cómo se ve HTML y cómo funciona a un nivel básico. También deberías poder escribir algunos elementos y atributos. Los artículos posteriores de este módulo profundizan en algunos de los temas introducidos aquí, así como en la presentación de otros conceptos del lenguaje.

  • A medida que comiences a aprender más sobre HTML, considera aprender los conceptos básicos de CSS (hojas de estilo en cascada). CSS es el lenguaje utilizado para dar estilo a las páginas web, como cambiar fuentes o colores o alterar el diseño de la página. HTML y CSS funcionan bien juntos, como pronto descubrirás.

Vease también