Cours de creation site web
Cours sur le langage HTML.
Plan
Le langage HTML
le lien vers les supports de cours de Fabien Torre sur le langage HTML.
Qu'est ce que l'HTML?
HTML est le langage de balisage hypertexte utilisé dans le Web (HyperText Markup Language).
Ce n'est pas un langage de programmation proprement dit.
Ce sont "simplement" des balises pour mettre en forme (avec des liens, en tableau, etc ) du texte et des images.
Pour avoir une idée de l'aspect d'une page écrite en HTML, cliquez sur "Affichage" (ou "View") dans votre navigateur, puis sélectionnez "page source".
Qu'est ce qu'une balise?
Une balise est une "instruction" comprise entre crochets qui possède un nom et parfois des attributs.
est, par exemple, la balise utilisée pour spécifier qu'il faut passer à la ligne.
La plupart des balises doivent être ouvertes puis refermées.
On retrouvera donc souvent une balise de début et une balise de fin.
La balise de fin porte le même nom que la balise de début mais est en plus précédée du signe /.
Nous aurons donc: (ouverture) et (fermeture) .
Par exemple: mon texte en gras (bold).
Le nom de la balise (contenu entre les crochets) n'est pas sensible à la casse:
il peut être écrit indifféremment en majuscule, en minuscule ou en un mélange des 2.
L'attribut d'une balise est défini comme suit: nom_attribut="valeur"
Par exemple, la balise utilisée pour faire un lien a pour nom "a", et pour nom d'attribut "href".
Ainsi, permet de faire un lien vers la page principale du site de Google.
Dans ce cas, la valeur de l'attribut "href" est donc "".
De quoi avez-vous besoin ?
Pour créer une page Web en HTML, vous avez besoin de:
- un navigateur (Internet Explorer, Netscape, Mozilla, etc ), pour visualiser le résultat;
- un éditeur HTML (Notepad ou WordPad feront très bien l'affaire par exemple), pour créer votre page HTML;
- NB: vous n'aurez pas besoin d'être connecté à Internet pour créer votre site.
Présentation des balises usuelles
le lien vers des tutoriaux sur les balises de base.
Votre premier document
- copiez ceci dans votre éditeur:
Mon titre
Voici mon premier document!
- sauvegardez le document avec comme extension ".htm" ou ".html", et comme type "texte seulement" ou "tout type (*.*)";
- puis double-cliquez sur le document: votre navigateur par défaut sera alors ouvert sur la page.
Explications des nouvelles balises utilisées:
- et : informent votre navigateur qu'il s'agit d'une page HTML; la première balise doit donc être la première de votre code, et la seconde doit être la dernière.
- et : informent votre navigateur qu'il s'agit de l'en-tête de votre page; cette en-tête comprend pour l'instant le titre de votre page; la balise est toujours placée juste après la balise .
- et : informent votre navigateur qu'il s'agit du titre de votre page; ce titre sera placé dans la barre tout au-dessus de votre navigateur; ces balises doivent se situer à l'intérieur de la balise "head", c'est-à-dire entre et .
- et : informent votre navigateur qu'il s'agit du corps de votre document; c'est là que vous allez placer textes, images, et tout ce que contiendra votre page; la balise doit se situer après la balise de fermeture de l'en-tête .
- On peut donc faire une première constatation : le code d'une page web est composé de 2 parties, l'en-tête de la page (HEAD) et le corps (BODY); et seul le corps de la page est affiché à l'écran: dans votre première page, il n'y a que la phrase "Voici mon premier document!" qui s'est affichée.
Balises simples
: passage à la ligne;- : mettre un texte en gras (bold);
- : mettre un texte en italique;
- : souligner un texte (underline);
- : centrer un texte;
- etc
Exemple
En tapant ça:
Mon texte
Et la suite
Vous obtenez ça:
Mon texte
Et la suite
Les commentaires
Balises de mise en forme
La balise de couleur
Mon texte
Mon texte
Le premier exemple est utilisable pour quelques couleurs prédéfinies: red, green, black
Sinon, vous pouvez utiliser le code commençant par #, basé sur le système "RGB" (Red-Green-Blue):
- les 2 premiers chiffres (en base 16, donc allant de 0 à F) fournissent le taux de rouge dans la couleur,
- les 2 suivants le taux de vert,
- et les 2 derniers le taux de bleu.
Par exemple, si vous voulez obtenir du rose, mélange du rouge et du bleu, tapez Mon texte
Choisissez vos couleurs à partir du suivant
La balise de taille
- Taille absolue (de 1 à 7):
Mon texte
Mon texte
Mon texte
Mon texte
Mon texte
Mon texte
Mon texte - Ou taille relative:
Mon texte
Mon texte
Mon texte
Mon texte
Les listes
En tapant ça:
- Ligne 1
- Ligne 2:
- Sous-Ligne 2.1
- Sous-Ligne 2.2
- Sous-Ligne 2.1
Vous obtenez ça:
? Ligne 1
? Ligne 2
- Sous-Ligne 2.1
- Sous-Ligne 2.2
Explication:
- correspond aux listes numérotées (Ordered List);
- aux listes à puces (Unordered List);
- et
- sert à spécifier qu'on démarre un nouvel élément de liste;
- à noter que existe également, mais n'est pas nécessaire, car supposé à l'ouverture du
- suivant, ou à la fermeture de liste
Enfin, vous pouvez également spécifier les types de numérotations ou de puces utilisées:
?
et
servent respectivement à ouvrir une nouvelle table, et fermer la table courante;et servent à définir une ligne du tableau;et servent à définir une cellule du tableau (à noter que n'est pas indispensable, pour la même raison que ). et servent à définir un titre de ligne ou de colonne (le texte apparait alors centré en gras dans la cellule correspondante);- et et servent à définir un titre pour le tableau.
- border: spécifie l'épaisseur du cadre extérieur, en pixels. Avec la valeur 0, le cadre est invisible;
- cellspacing: épaisseur en pixels autours de chaque cellule;
- cellpadding: épaisseur en pixels entre l'élément de la cellule et le cadre;
- width: largeur occupée par le tableau en pixels ou en pourcentages;
- align: l'alignement du tableau: center, right ou left.
: fusion horizontale de 2 cellules; : fusion verticale de 2 cellules. Images et références
Les images
Attributs:
- align: alignement désiré de l'image (de même que pour les tableaux)
- alt: texte associé à l'image (apparait quand la souris passe au dessus, ou en remplacement de l'image si celle-ci n'existe pas)
- width: longueur
- height: hauteur
Les liens hypertextes
Liens à l'intérieur d'une même page:
- Placer: à l'intérieur de votre document
- Texte du lien désigne alors l'emplacement désigné
- à utiliser par exemple en bas de page pour proposer de revenir en haut de page.
Les chemins d'accès
Les chemins d'accès peuvent être:
- absolus: c'est-à-dire qu'on spécifie l'adresse complète de ce à quoi on fait référence:
par exemple pour une image, ou pour un site; - ou relatifs: la référence est faite par rapport à l'endroit où l'on se trouve:
par exemple ou désignant des fichiers situés dans le même répertoire que le fichier qui y fait référence.
Dans ce cas:
- "." désigne le répertoire courant,
- et ".." désigne le répertoire parent.
Par exemple, dans votre répertoire nommé "site" se trouve un répertoire nommé "images" et un fichier nommé "".
Dans le fichier "", vous voulez faire référence à l'image nommée "" du répertoire "images".
La référence se fait alors comme suit:
Maintenant, vous êtes dans un fichier du répertoire "images" et vous voulez faire référence à votre fichier "".
Alors la référence se fait comme suit: Ma refOptions de la balise body
Nous avons maintenant assez d'éléments pour introduire les principales options de la balise body:
- bgcolor=couleur: couleur de fond
- background=chemin_image: image de fond
- text=couleur: couleur du texte
- link=couleur: couleur des liens
- vlink=couleur: couleur des liens visités
- alink=couleur: couleur des liens actifs (au moment où vous cliquez dessus)
Organisation du texte
Les paragraphes
bla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla bla
bla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla blabla blablabla blabla blablablabla blabla bla
bla blablabla blabla blablablabla blabla bla
bla blablabla blabla blablablabla blabla bla
bla blablabla blabla blablablabla blabla bla
L'indentation
Les titres
de
à
:
Mon texte
Mon texte
Mon texte
Mon texte
Mon texte
Mon texte
Les séparateurs
Les caractères spéciaux
Les caractères tels étant interprétés par votre navigateur comme marqueurs de balises, comment faire pour les afficher dans un texte sans qu'ils ne soient interprétés?
Pour cela, il existe les caractères spéciaux. Ceux-ci commencent par le signe "&" et finissent par un point-virgule ";".
Ainsi, par exemple, il faut taper > pour obtenir le signe >.Cette liste est également utile pour afficher des caractères n'existant pas sur notre clavier.
Ainsi, par exemple, pour obtenir le caractère €, il faut écrire €une liste des caractères spéciaux en HTML.
Les frames
Exemple
FramesNo Frames? No Problem!
Take a look at our no-frames version.
Référence entre pages
Si maintenant vous voulez qu'en cliquant sur un lien de la page "menu", ce soit la page "pagePrincipale" qui soit modifiée, vous écrivez:
Map, area et images réactives
3 types de formes peuvent être utilisées :
- la forme rectangulaire, comme dans l'exemple : shape="rect" ? coords="left-x, bottom-y, right-x, top-y"
- la forme sphérique : shape="circle" ? coords="center-x, center-y, radius"
- ou la forme polygonale : shape="poly" ? coords="x1, y1, x2, y2, , xN, yN"
Exercice 1
Ecrire le code HTML permettant d'obtenir ceci:
BIG TITRE
Une petite intro
Ma liste de refs:
? Générale:
? Relative:
Et mon tableau:
Titre
Texte 1
Texte 2
Texte 3
Texte 4
Texte 5
Exercice 2
Créez votre CV en HTML.
Le minimum qui doit y figurer est:
- en haut à gauche: Nom, Prénom, Nationalité, Date et lieu de naissance, Coordonnées (mail, tel, adresse),
- en haut à droite: une photo,
- un tableau récapitulatif de votre cursus scolaire,
- une liste spécifiant votre expérience professionnelle,
- et vos loisirs,
le but étant de simultanément:
- créer une page claire,
- créer une page agréable,
- et que le code qui l'a généré soit également le plus clair possible.
HTML reste aujourd'hui le langage de publication sur le web par excellence.
Cependant, on note l'abandon des balises de pure mise en page, celles-ci étant avantageusement remplacées par les feuilles de style.
Celles-ci permettent de définir globalement les mises en page à effectuer. Ainsi, il est recommandé de ne plus utiliser de balises comme FONT, B, I, etcDe manière générale, les balises HTML ne doivent être utilisées que pour structurer le document, et non plus pour préciser son apparence.
Les feuilles de style CSS
le lien vers les supports de cours de Fabien Torre sur les feuilles de style CSS.
Et la feuille de style utilisée pour cette page.
Principe
L'idée de l'utilisation de feuilles de style (en anglais Cascading Style Sheets (CSS)) est de dissocier le contenu d'un document de sa mise en forme.
Les intérêts de cette séparation sont nombreux :
- un style, appliqué à toutes les pages d'un site, assure la cohérence graphique de ce site ;
- la maintenance d'un site en est facilitée, un changement de charte graphique ne portera que sur la feuille de style et la modification sera naturellement propagée à toutes les pages ;
- le code HTML est lisible et facilement modifiable, sans que l'on ait à penser en même temps au contenu et à son apparence ;
- les pages, dégagées des balises de mise en forme, sont plus légères, donc plus rapides à circuler sur un réseau (la feuille de style est, le plus souvent, très légère et ne sera chargée qu'une seule fois pour l'ensemble des documents qui l'utilisent) ;
- les balises donnent une indication sur la nature du contenu et cette indication pourra être utilisée par un moteur de recherche.
La feuille de style est donc un fichier externe à vos pages HTML. Ce fichier doit avoir comme extension .css
Et pour spécifier qu'une page HTML utilise une certaine feuille de style (qu'on nomme ici ), on écrit ceci dans l'en-tête de la page HTML (balises head):
Remarque: les navigateurs gèrent souvent une même feuille de style de manière différente
Après avoir écrit une feuille de style, il conviendra donc de vérifier l'apparence du document avec un maximum de navigateurs.
Enfin, et surtout, il faut s'assurer impérativement que le document reste lisible même sans la feuille de style.Utilisation
La syntaxe générale dans une feuille de style est la suivante:
nomClasse{
nomAttribut1: valeur1;
nomAttribut2: valeur2;
etc
}
Les commentaires sont inclus entre /* et */
Par exemple:
H1{
font-size: 20pt;
text-align: center;
text-decoration: underline;
color: red;
}
va permettre de définir que tout titre H1:
- est de taille 20 (pt = point),
- est centré
- est souligné,
- et est de couleur rouge.
Liste des propriétés CSS
Une liste complète des propriétés CSS est accessible .
Voici une liste des plus utilisées: on présente ici d'abord le nom de l'attribut, sa signification, puis la liste de ses valeurs possibles:- Propriétés de police:
- font-size: taille de police:
numérique ( 10pt ) / xx-small / x-small / small / medium / large / x-large / xx-large - font-family: famille de police:
Arial / Helvetica / Times New Roman / Sans Serif - font-style: style de police:
normal / italic / oblique - font-weight: graisse de police:
normal / bold / et de 100 (très fin) à 900 (très gras) - font-variant: variante de police:
normal / small-caps (petites capitales) - color: couleur de police:
red / #FF0000
- font-size: taille de police:
- Mise en forme du texte:
- text-decoration: décoration du texte:
underline / overline / line-through / blink / none - text-transform: transformation du texte:
capitalize (début des mots en majuscule) / uppercase / lowercase / none
- text-decoration: décoration du texte:
- Agencement du texte:
- display: position par rapport au reste: nouveau paragraphe (block) / ou à la suite du paragraphe précédent (inline)
- text-align: alignement horizontal: à gauche (left) / centré (center) / à droite (right) / justifié (justify)
- text-indent: retrait du texte: numérique
- line-height: interligne: numérique
- vertical-align: alignement vertical: aligner en haut (top) / aligner au milieu (middle) / aligner en bas (bottom) / aligner sur la ligne de base, ou en bas s'il n'y a pas de ligne de base (baseline) / mettre en indice, sans réduire la taille de la police (sub) / mettre en exposant, sans réduire la taille de la police (super) / aligner sur le bord supérieur de l'écriture (text-top) / aligner sur le bord inférieur de l'écriture (text-bottom)
- Mise en forme de listes:
- list-style-type: type de représentation:
numériques: decimal / lower-alpha / upper-alpha / lower-roman / upper-roman
à puces: disc / circle / square - list-style-position: retrait des listes:
puces et numérotation dans le corps de la liste (inside) / retrait à gauche des puces et numérotation (outside) - list-style-image: graphique de puces personnalisées:
url()
- list-style-type: type de représentation:
- Couleurs et arrière-plans:
- color: couleur du texte
- background-color
- background-image
- background-repeat: effet de répétition (repeat, repeat-x, repeat-y, no-repeat)
- background-attachement: effet de filigrane (scroll, fixed)
- background-position
- Retraits extérieurs et intérieurs:
- margin (retrait extérieur): numérique
- margin-top
- margin-bottom
- margin-left
- margin-right
- padding (retrait intérieur)
- padding-top
- padding-bottom
- padding-left
- padding-right
- Cadres:
- border: numérique
- border-top
- border-bottom
- border-left
- border-right
- border-style (solid, double, groove, ridge, inset, outset, dotted, dashed)
- border-style-top
- border-style-bottom
- border-style-left
- border-style-right
- border-width
- border-color
- Positionnement absolu des éléments:
Balises div et span:- position (static, absolute, relative)
- top
- left
- width
- height
- visibility (visible, hidden)
- z-index (Position de la couche en cas de superposition)
- Pseudo-classes pour liens hypertextes:
- A:link
- A:hover (passage de souris)
- A:active (click de souris)
- A:visited (prioritaire sur les précédents ne pas utiliser mais préférer le VLINK de la balise BODY)
Exemples
Pour définir de façon globale la mise en forme du corps du document:
body{
background-color: #CCFFCC;
font-size: 11pt;
color: #000000;
font-family: Helvetica, Arial, sans-serif;
}
Pour définir de façon globale la mise en forme des liens hypertextes:
A:link{
text-decoration: none;
color: #0000FF;
background-color: inherit;
}
Exercices sur les feuilles de style
Modifier vos pages précédemment créées en utilisant les feuilles de style.
Pour cela, vous pouvez utiliser les interfaces écrites par Dominique Gonzalez et récupérer les différents styles pour les inclure dans vos propres pages :
- appliquer des styles aux ;
- aux ;
- aux .
?
?
?
?
?
Les tableaux
Par exemple en tapant ça:
Nom 1 | Nom 2 |
---|---|
Cellule 1 | Cellule 2 |
Vous obtenez ça:
Mon titre | |
Nom 1 | Nom 2 |
Cellule 1 | Cellule 2 |
Options de la table:
Exemple
En remplaçant la balise
Mon titre | |
Nom 1 | Nom 2 |
Cellule 1 | Cellule 2 |
Options des cellules: