Les tableaux (x)html
Mise en page
Ancienne méthode de layout
Ce code est toujours valide et s'affichera correctement dans la plupart des navigateurs.Cependant, depuis le 31/07/2003 l'infobrol n'est plus affiché en utilisant des tableaux pour contrôler sa mise-en-page, mais une combinaison de css et de classe.
Cette page montre donc comment se libérer des tableaux pour la mise en forme.
Comme nous l'avons vu dans l'introduction, de nombreuses mises en pages reposent sur l'utilisation de tableaux. Nous savons aussi que l'affichage d'un tableau nécessite des calculs, et donc prend du temps. Il est dès lors possible de séparer les éléments du tableau principal en éléments plus petits et donc plus rapides à afficher.
Prenons par exemple le cas d'une page composée d'un tableau principal en trois parties : une barre de navigation supérieure, une barre de navigation latérale, et le contenu réel de la page.
Voici le code qui serait généré par un éditeur WYSIWYG :
Nous devrions opter pour une mise en page en deux tableaux. Ces derniers seraient donc chargés individuellement, ce qui nous permet d'accélérer l'affichage du premier, au lieu d'attendre que toute la page soit chargée.
Cette technique nous permet d'accélérer l'affichage du bandeau supérieur, mais peut générer certains espaces vides, ou des incohérences d'affichages sous Internet Explorer pour Mac par exemple. Il est donc préférable de tester la mise en page sous différents navigateurs.
Chacun son style...
L'exemple précédent montre qu'il est possible de réaliser une mise en page qui s'affichera plus rapidement, mais qui reste soumise aux comportements capricieux des navigateurs face aux tableaux.
Nous allons donc réaliser le même type de mise en page à l'aide des balises div, qui puisent leurs informations dans notre feuille de style (CSS).
Par l'utilisation des feuilles de style CSS2, nous gagnons en souplesse dans la mise en page. En effet, il suffit de modifier la feuille de style pour modifier la mise en page du document.
Nous devrons donc veiller à ne plus utiliser de référence à des positions, en nommant de préférence les attributs en fonction du contenu.
Les informations de styles seront donc les suivantes :
<style type="text/css"> <!-- div#b_s { background:#ffff00; width:auto; margin:0; padding:0.5em; } div#c { float:right; width:75%; background:#0000ff; margin-left:25%; padding:0.5em; } div#b_l { background:#ff0000; margin-right:75%; padding:0.5em; } //--> </style>
float:right
La déclaration du style et le code html de la page peuvent vous heurter : les plus curieux d'entre-vous auront remarqué que je présente le contenu de la page avant celui du menu de navigation qui se trouve pourtant à gauche dans la page.Nous pouvons réaliser ce genre d'opération grâce à la déclaration float:right qui détermine l'affichage du contenu de la page. Ceci est assez important lors du référencement dans les moteurs, car le code placé en haut de page est considéré comme ayant plus de pertinence.
Version en cache
21/01/2025 07:01:34 Cette version de la page est en cache (à la date du 21/01/2025 07:01:34) afin d'accélérer le traitement. Vous pouvez activer le mode utilisateur dans le menu en haut pour afficher la dernère version de la page.Document créé le 21/07/2002, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/html-optimisation-tableaux-suite.html
L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.