Sur le Web, un composant est un programme qui permet de fournir une interface intégrable, conçue pour un usage précis, mais personnalisable par chaque développeur.
Par exemple, si je développe et diffuse un composant de galerie d'images, d'autres développeurs pourront intégrer simplement mon composant sur leur site, et y ajouter les images de leur choix.
Les composants permettent donc d'enrichir le contenu, l'esthétique, et/ou les interactions proposés par un site Web, en réutilisant du code qui n'a pas été écrit spécifiquement pour ce site.
Il existe de très nombreux composants publiés sur Internet et utilisables gratuitement. Pour la plupart, ils sont basés sur la bibliothèque « jQuery » (dont nous parlerons plus tard dans ce cours). Mais nombreux ont été conçus en JavaScript/DOM natif (aussi appelé « Vanilla JavaScript »), et peuvent donc fonctionner sans jQuery.
Note : dans le cadre de ce cours, l'usage (direct ou pas) de jQuery ne sera pas accepté.
Voici quelques exemples de composants natifs intégrables librement :
Vous pourrez trouver d'autres composants natifs sur le site Vanilla List.
À ce stade, nous allons apprendre à réaliser un composant simple, dans le sens où celui-ci ne sera pas suffisamment modulaire pour être intégré plusieurs fois sur une même page. Nous verrons plus tard comment faire cela.
XIII-A-1. Généricité et instructions d'intégration▲
Afin que notre composant puisse être intégré de manière personnalisée par chaque développeur, quels que soient le site Web en question et son contenu, il est important de définir quelques règles et abstractions.
D'abord, un composant doit être simple à intégrer, et un utilisateur de composant ne devrait jamais avoir à consulter ni modifier le code source du composant. Il va falloir donc que le composant soit suffisamment générique et configurable depuis le site Web qui l'intégrera.
Par exemple, un composant de galerie d'images doit s'adapter à une liste d'images fournie par un développeur désirant l'intégrer, et l'intégrateur ne devrait en aucun cas avoir à modifier la liste d'images dans le code source du composant.
Pour cela, un composant :
- ne doit pas contenir de valeurs et références littérales ; (ex. : nombre d'images et/ou URL des images stockés « en dur » dans le code du composant) ;
- doit définir et documenter les règles et contraintes éventuelles que devront respecter les intégrateurs du composant.
Exemples d'instructions d'intégration fournies par la documentation d'un composant :
- toutes les images à afficher dans la galerie doivent être des balises <img> portant la classe carousel-img ;
- ou encore : appeler la fonction creerGallerie() (définie par le composant) en passant en paramètres l'identifiant du DIV devant contenir la galerie, et un tableau d'URL d'image.
Prenez le temps d'analyser les instructions d'intégration des composants listés plus haut.
XIII-A-2. Exercice 1 : développer et documenter un composant simple▲
Pour mettre en pratique cette partie du chapitre, développer un des trois composants suivants, et fournir la page de documentation associée.
La page de documentation doit contenir :
- une description concise du composant : à quoi il sert, quelles sont ses fonctionnalités et avantages éventuels ;
- une démonstration du composant, pour le tester depuis la page ;
- les instructions permettant d'intégrer simplement ce composant à son site ;
- la description des fonctions et/ou paramètres éventuellement fournis par le composant ;
- BONUS : la liste des navigateurs (et leur version) sur lesquels le composant fonctionne ;
- BONUS : le composant et sa documentation publiés sur GitHub.
S'inspirer de la documentation des composants fournis plus haut en exemple.
Conseil pratique : pour afficher du code source sur une page HTML sans que celui-ci ne soit interprété par le navigateur, utiliser la balise <xmp>.
XIII-A-2-a. Composant : Carousel▲
Un « carousel » est un composant de galerie d'images permettant à l'utilisateur de passer d'une image à l'autre, et éventuellement d'agrandir une image en plein écran.
Certains carousels passent automatiquement d'une image à l'autre, à l'aide d'un minuteur (setTimeout
(
) ou setInterval
(
)).
Pour développer un carousel, il faut maîtriser :
- les sélecteurs DOM (
getElementById
(
), getElementsByClassName
(
) et/ou getElementsByTagName
(
)) ;
- la manipulation de styles et/ou classes CSS en JavaScript ;
- la capture d'événements onclick ;
- et l'opérateur modulo (%).
Solution : Jsfiddle
<button id
=
"next"
>
next</button>
<div id
=
"carousel"
>
<img class
=
"carousel-img"
src
=
"https://encrypted-tbn1.gstatic.com/images?q=tbn:ANd9GcTeiCMhoMrQyPFOsY9cX1tUZm39RAVvWGI3KTt5j3MhYAbYtmqm"
>
<img class
=
"carousel-img"
src
=
""
>
<img class
=
"carousel-img"
src
=
""
>
</div>
var images
=
document
.getElementsByClassName
(
'carousel-img'
);
var imageVisible =
0
;
function changerImage
(
) {
images
[
imageVisible].
classList.remove
(
'visible'
);
imageVisible = (
imageVisible +
1
) %
images
.
length;
images
[
imageVisible].
classList.add
(
'visible'
);
}
document
.getElementById
(
'next'
).
onclick
=
changerImage;
changerImage
(
);
XIII-A-2-b. Composant : Accordéon▲
Un « accordéon » est un composant proposant plusieurs rubriques à l'utilisateur, et lui permettant d'afficher le contenu d'une rubrique à la fois, en cliquant sur son titre.
Pour développer un accordéon, il faut maîtriser :
- les sélecteurs DOM (
getElementById
(
), getElementsByClassName
(
) et/ou getElementsByTagName
(
)) ;
- la manipulation de styles et/ou classes CSS en JavaScript ;
- la capture d'événements onclick ;
- et la gestion du scope.
Solution : Jsfiddle
<section>
<header>Le programme de Donald Trump</header>
<article>La durée de vie d'un décret est par ailleurs limitée: un président donc abroger un décret d'un prédécesseur, comme l'a fait Donald Trump en annulant plusieurs textes signés par Barack Obama, sur les projets d'oléoducs Keystone ou sur le financement ...</article>
</section>
<section>
<header>Donald Trump accuse les juges...</header>
<article>Dire que Donald Trump a peu apprécié le blocage de son décret anti-immigration par un juge fédéral est un euphémisme. Samedi 4 février, il l'a désigné à la vindicte des 23 millions d'abonnés de son compte Twitter, le qualifiant de « soi-disant juge ...</article>
</section>
<section>
<header>Donald Trump rencontrera ses alliés de l'Otan</header>
<article>En mai aura lieu une rencontre entre Donald Trump et ses alliés de l'Otan, a annoncé dimanche la Maison Blanche, après un entretien téléphonique entre le président américain et le secrétaire général de l'Alliance atlantique Jens Stoltenberg. Donald ...</article>
</section>
var headers =
document
.getElementsByTagName
(
'header'
);
var articles =
document
.getElementsByTagName
(
'article'
);
function afficherArticle
(
i) {
articles[
i].
classList.add
(
'visible'
);
}
function cacherArticles
(
) {
for (
var i =
0
;
i <
articles.
length;
i++
) {
articles[
i].
classList.remove
(
'visible'
);
}
}
function pourAfficherArticle
(
i) {
return function(
){
cacherArticles
(
);
afficherArticle
(
i);
};
}
for (
var i =
0
;
i <
headers.
length;
i++
) {
headers[
i].
onclick
=
pourAfficherArticle
(
i);
}
XIII-A-2-c. Composant : Galerie vidéo▲
Une galerie vidéo permet à l'utilisateur de visualiser une vidéo, en cliquant parmi une sélection fournie.
Pour développer une galerie vidéo, il faut maîtriser :
- les sélecteurs DOM (
getElementById
(
), getElementsByClassName
(
) et/ou getElementsByTagName
(
)) ;
- la capture d'événements onclick ;
- l'intégration d'<iframe> (ex. : à l'aide de innerHTML) ;
- et la gestion du scope.
Solution : Jsfiddle
var videos =
[
'https://www.youtube.com/embed/0uaQMxBjd5E'
,
'https://www.youtube.com/embed/c8ZPn6p5khI'
,
'https://www.youtube.com/embed/ikkrEOD1BbQ'
,
];
var video =
document
.getElementById
(
'video'
);
var buttons =
document
.getElementsByTagName
(
'button'
);
function pourAfficherVideo
(
i) {
return function(
) {
video.
innerHTML =
'<iframe width="320" height="200" src="'
+
videos[
i]
+
'?autoplay=1"></iframe>'
};
}
for (
var i =
0
;
i <
buttons.
length;
i++
) {
buttons[
i].
onclick
=
pourAfficherVideo
(
i);
}