Contenu

Texte

Lorsqu’on écrit du code HTML, on écrit du texte. Le premier et principal contenu dont est composé le web est également le texte (lire à ce sujet le vieil article d’Olivier Reichenstein, Web Design is 95% Typography).

Les paragraphes

Les paragraphes <p> sont les éléments HTML parmi les plus utilisés.

<p>
  95% de l’information sur le web est constitué d’écrit. Il est tout à fait logique de dire qu’un designer web devrait recevoir une bonne formation dans la discipline principale de la mise en forme de l’information écrite, en d’autres termes, la typographie (Olivier Reichenstein).
</p>

Les listes

Les listes existent en 3 variantes:

Les listes HTML nécessitent une structure spécifique:

<ul> et <ol> doivent inclure et être les parents directs de <li>, les list items, éléments de la liste.

Listes non ordonnées

Ce sont les types de listes les plus couramment utilisés. Elles servent à regrouper une liste d’éléments individuels, sans ordre particulier.

<p>Liste de courses :</p>
<ul>
  <li>Lait </li>
  <li>Pain </li>
  <li>Chocolat </li>
  <li>Plus de chocolat…</li>
</ul>

Les éléments de la liste sont affichés (par défaut) avec des puces.

Liste de courses :

Listes ordonnées

Les listes ordonnées sont utilisées lorsque l’ordre de ses éléments est important.

<ol>
  <li>Première étape </li>
  <li>Deuxième étape </li>
  <li>Troisième étape </li>
</ol>

Les listes ordonnées sont (par défaut) automatiquement numérotées par le navigateur. Il n’est pas nécessaire d’inclure les nombres dans le code HTML.

  1. Première étape
  2. Deuxième étape
  3. Troisième étape

Bloc de citation

Les blocs de citation sont utilisés pour identifier une citation.

<p>Tim Berners-Lee a déclaré: </p>
<blockquote>
  « Le web est plus une invention sociale que technologique. Je l’ai conçu pour qu’il ait un effet social – aider les gens à travailler ensemble – et non comme un jouet technologique. »
</blockquote>

Tim Berners-Lee a déclaré:

« Le web est plus une invention sociale que technologique. Je l’ai conçu pour qu’il ait un effet social – aider les gens à travailler ensemble – et non comme un jouet technologique. »

Les titres

Il existe 6 niveaux de titres disponibles, allant de <h1> (le plus important) à <h6>.

Les titres sont destinés à être utilisés avec les paragraphes et les listes, pour dessiner la structure naturelle du document.

Sémantique en ligne

Si les paragraphes et les listes visent à identifier des blocs de texte, il est souvent nécessaire de donner du sens à un mot (ou à quelques mots) au sein du texte.

Strong

Pour les mots importants, on utilise la balise <strong>:

<p>
  C’est <strong> important </strong> !
</p>

C’est important !

Par défaut, les éléments <strong> sont affichés en gras. ⚠️ Attention, <strong> ne doit pas être utilisé uniquement pour mettre du texte en gras, mais pour donner au texte plus d’importance (avec l’aide de CSS, on pourra préférer changer sa couleur plutôt que sa graisse).

Accentuation

Pour appuyer un mot au sein du texte,on utilise la balise <em>:

<p>
  Ceci est <em>parfaitement</em> clair.
</p>

Ceci est parfaitement clair.

Par défaut, les éléments <em> sont affichés en italique. ⚠️ Attention, <em> ne doit pas être utilisé uniquement pour mettre du texte en italique, mais pour donner au texte plus d’importance (avec l’aide de CSS, on pourra préférer changer sa couleur plutôt que son style).

N.B. : Lorsque le sens l’exige, on peut utiliser la balise <i>, par exemple pour l’inclusion d’un terme en langue étrangère :

<p>
  Archimède s’écria : <i>Eurêka !</i>
</p>

Abréviations

Des abréviations telles que W3C ou ÉSAD peuvent utiliser l’élément <abbr>:

On ajoute généralement un attribut title pour spécifier la description de l’abréviation, qui apparaît au survol de l’élément.

<p>
  J’étudie à l’<abbr title="École supérieure d’art et de design">ÉSAD</abbr> des Pyrénées.
</p>

J’étudie à l’ÉSAD des Pyrénées.

Citations en ligne

L’élément <blockquote> est un élément de niveau bloc. Il a une version en ligne, pour les citations intégrées à une phrase :

<p>
  J’ai dit <q>“Bonjour monde”</q> et je suis parti.
</p>

J’ai dit “Bonjour monde” et je suis parti.

Non-sémantique

Lorsque l’on balise un élément de contenu qui n’a pas de signification particulière (par exemple, pour ajouter une couleur ou une graisse à un mot pour une raison autre que l’emphase), on peut utiliser l’élément <span>.

<p>
  Ceci est un <span>élément</span> singulier.
</p>

Les liens sont des éléments essentiels du HTML ; le Web a été conçu pour être un réseau d’information constitué de documents liés entre eux.

En HTML, les liens sont des éléments en ligne écrits avec la balise <a> (pour anchor, ancre).

L’attribut href (référence hypertexte) est utilisé pour définir la cible du lien (à laquelle on accède lorsqu’on clique).

<p>
  Vous êtes <a href="https://perdu.com">perdu⋅es</a> ? 
  Naviguez dans le <a href="https://desordre.net">Désordre</a>.
</p>

Les liens constituent l’interaction principale d’une page Web : on navigue d’un document à un autre en cliquant sur les liens.

On peut définir trois types de cibles :

Ancres cibles

On l’utilise naviguer dans une même page. On peut cibler un élément spécifique grâce à son attribut id.

Par exemple, <a href="#top"> fait défiler la page jusqu’à l’élément dont l’id est “top” :

Haut de page

URL relatives

Si on souhaite définir un lien vers une autre page du même site Web, on utilise des URL relatives (relatives au document courant, à la page en cours).

Exemple : le dossier “mon-site” contient deux fichiers HTML (index.html et contact.html), mais aussi un sous-dossier “projets” qui contient d’autres pages.

 mon-site
     index.html
     contact.html
     projets
         projet1.html
         projet2.html

Dans index.html, on peut écrire :

<p>
    Regardez mes projets :
</p>
<ul>
    <li><a href="projets/projet1.html">Un super projet</a></li>
    <li><a href="projets/projet2.html">Un projet génial</a></li>
    <!-- les pages sont contenues dans le dossier “projets” ;
    on donne donc leur chemin “relatif” à la page d’accueil -->
</ul>
<p>
    Pour plus d’informations, <a href="contact.html">contactez-moi</a>.
    <!-- la page “contact” est au même niveau que la page d’accueil -->
</p>

URL absolues

Pour partager le lien vers un projet, il faudra transférer le site en ligne, et transmettre l’URL absolue de la page HTML.

Cette URL peut être segmentée en 3 parties:

Cette URL absolue est autonome : peu importe où l’on affiche le lien, il contient toutes les informations nécessaires pour trouver le bon fichier, dans le bon domaine, avec le bon protocole.

On utilise généralement des URL absolues quand on veut produire un lien vers un autre site Web. La page contact.html pourra ainsi contenir un lien vers le site de l’ÉSAD :

<p>
  J’étudie à l’<a href="https://esad-pyrenees.fr/">ÉSAD Pyrénées</a>.
</p>

Images & médias

Les images sont le premier contenu non textuel apparu sur le Web. Seuls quelques formats d’image peuvent être affichés dans un navigateur : principalement .jpg, .gif (animé ou non), .png (transparent ou non) ou .svg (format d’images vectorielles).

Voir les différents formats de fichiers image

jpg

Les images JPG sont conçues pour gérer de grandes palettes de couleurs sans augmenter de façon exorbitante la taille du fichier. Cela les rend parfaits pour les photos et les images comportant de nombreux dégradés. En revanche, les fichiers JPG ne permettent pas de pixels transparents.

gif

Les GIF sont l’option par excellence pour les animations simples, mais ils ont en revanche une limite en termes de palette de couleurs : on ne les utilise jamais pour des photos. Les pixels transparents sont une option binaire pour les GIF, on ne peut pas avoir de pixels semi-opaques. Cela peut rendre difficile l’obtention de niveaux de détail élevés sur un arrière-plan transparent. Pour cette raison, il est généralement préférable d’utiliser des images PNG si l’on n’a pas besoin d’animation.

png

Les PNG sont parfaits pour tout ce qui n’est pas une photo ou une animation. Pour les photos, un fichier PNG de même qualité (tel que perçu par l’œil humain) serait généralement plus volumineux qu’un fichier JPG équivalent. Cependant, ils gèrent parfaitement la transparence (PNG 24) et n’ont pas de limites de palette de couleurs. Cela les rend parfaits pour les icônes, graphiques, logos, etc.

svg

Contrairement aux formats d’image bitmap (basés sur des pixels) ci-dessus, SVG est un format graphique basé sur des vecteurs. Les SVG peuvent être agrandis ou réduits à n’importe quelle dimension sans perte de qualité. Cette propriété fait des images SVG un outil formidable pour le design responsive.

La syntaxe

Les images utilisent l’élément <img>, qui est un élément à fermeture automatique (il ne comporte qu’une balise d’ouverture).

L’attribut src définit l’emplacement de l’image. Comme pour les liens, on peut utiliser des URL relatives ou absolues.

 mon-site
     accueil.html
     logo.png
<h1><img src="logo.png" alt="Logo de mon super site"></h1>
<p>
    Bienvenue sur mon site !
</p>

Chaque image a deux dimensions: une largeur et une hauteur, exprimées en pixels.

Lors de l’insertion d’une image en HTML, le navigateur l’affichera automatiquement dans sa taille réelle. On peut spécifier les dimensions d’affichage d’une image grâce aux attributs width et height.

⚠️ Il est important de faire attention à la taille en pixels et au poids en Ko ou Mo des images que l’on utilise, notamment pour éviter le chargement d’images trop lourdes. En savoir plus

Audio & vidéo

Les balises <audio> et <video qui permettent d’insérer des médias audio et vidéo dans une page web sont décrites en détail dans la section dédiée.

<canvas> et <iframe>

La balise <canvas> ajoute la possibilité de créer des animations avec du code. Il peut s’agir de 2d (avec p5.js, ou paper.js par exemple) ou de 3d (avec three.js ou Zdog). Elle agit comme un espace rectangulaire dont le contenu est manipulable en javascript exclusivement. Voir la page dédiée à canvas

Les <iframe> sont un type de média particulier : ils constituent essentiellement une fenêtre vers une autre page Web. Ils sont aussi appelés embed. On les rencontre notamment si l’on veut intégrer une vidéo provenant d’un service externe (Youtube, Vimeo) :

<iframe width="560" height="315" src="https://www.youtube.com/embed/yfskVxCn_qo" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>

Structure

Lorsque l’on écrit un contenu HTML tel que des paragraphes, des listes ou des liens, on donne du sens à un texte. Mais il est souvent nécessaire de regrouper certains de ces éléments afin de mieux structurer le contenu et sa capacité de mise en forme CSS.

Une page de blog peut être divisée en 4 parties:

Il existe certains éléments HTML structurels que l’on peut utiliser comme conteneurs pour d’autres éléments.

En-tête : <header>

Le <header> est généralement le premier élément HTML du code. Il s’agit d’une introduction à la page Web, pouvant contenir le logo, un slogan et des liens de navigation.

<header>
    <h1><img src="logo.png" alt="Logo de mon super site"></h1>
    <p>
        Bienvenue sur mon site !
    </p>
    <nav>
        <ul>
            <li><a href="home.html">Accueil </a></li>
            <li><a href="projets.html">Projets</a></li>
            <li><a href="contact.html">Contact </a></li>
        </ul>
    </nav>
</header>

Pied de page : <footer>

Le pied de page est généralement le dernier élément d’une page, où les liens de navigation principaux sont répétés et les liens secondaires ajoutés.

<footer>
    <p>Mon super site © 2019</p>
    <nav>
        <ul>
            <li><a href="home.html">Accueil </a></li>
            <li><a href="projets.html">Projets</a></li>
            <li><a href="contact.html">Contact </a></li>
        </ul>
        <ul>
            <li><a href="privacy-policy.html">Règles de confidentialité </a></li>
            <li><a href="terms-of-use.html"> Conditions d’utilisation </a></li>
        </ul>
    </nav>
</footer>

Contenu principal : <main>

L’élément <main> contient, comme son nom l’indique, le contenu le plus important de la page.

Alors que toutes les pages Web d’un site Web contiennent des éléments communs et répétés de page en page (l’en-tête, la navigation, le pied de page, etc.), l’élément <main> se concentre sur un contenu unique.

Cet article fait partie de l’élément <main> de cette page Web, car son contenu est unique sur l’ensemble du site Web.

Annexe : <aside>

L’élément <aside> réside généralement à côté de l’élément principal et contient des informations supplémentaires relatives au contenu principal.

Sections et articles

Les éléments <section> et <article> permettent de grouper des contenus.

Leurs différences sémantiques sont minces. <section> est utile pour découper un document en multiples blocs. <article> est utile pour définir un contenu autonome. Tous deux sont sensés contenir un titre (<h1>, <h2>, etc.)

Figures

L’élément <figure> est généralement utilisé pour englober des images, illustrations, diagrammes, ou même des snippets de code. Il peut être utilisé en conjonction avec l’élément <figcaption> pour signaler la légende.

<figure>
    <img src="cat.jpg" alt="Une photo de mon chat">
    <figcaption>Mon chat est noir.</figcaption>
</figure>

Divisions

Comme pour la balise inline <span>, on a souvent besoin de grouper le contenu dans des blocs plus précis (généralement pour lui associer une mise en forme CSS). Dans ce cas, il est possible d’utiliser la balise <div>, qui ne porte aucun sens. Il faut veiller à l’utiliser le moins possible, pour garder le code HTML le plus sémantique possible.

Contenu adapté de Jeremy Thomas, sous license CC BY-NC-SA 4.0.