Introduction aux API web

Tout d'abord, nous verrons dans les grandes lignes ce qu'est une API : leur fonctionnement, comment les utiliser dans votre code, et leur structure. Nous verrons également quelles sont les principales API et leur utilisation.

Prérequis : Des connaissances de base en informatique, une compréhension de base du HTML et CSS, des notions de JavaScript (voir premiers pas, briques JavaScript, objets JavaScript).
Objectif : Se familiariser avec les API, ce qu'elles permettent de faire, et comment les utiliser.

Qu'est-ce qu'une API ?

Les API (Application Programming Interfaces soit « interface de programmation d'application » en français) sont des constructions disponibles dans les langages de programmation pour permettre aux développeuses et développeurs de créer plus facilement des fonctionnalités complexes. Elles fournissent une abstraction sur les parties de code plus complexes, fournissant ainsi une syntaxe plus facile à utiliser à la place.

En guise d'exemple concret, pensez à des branchements électriques dans une maison, appartement ou autre logement. Si vous souhaitez utiliser un appareil dans votre maison, il vous suffit de le brancher dans une prise et cela fonctionne. Vous n'essayez pas de le brancher directement à l'alimentation électrique : le faire serait réellement inefficace, et, si vous n'êtes pas électricienne ou électricien, difficile et dangereux à réaliser.

Deux multiprises branchées sur deux prises différentes. Chaque multiprise possède deux emplacements : un sur le haut et un sur la face. Sur ces emplacements, des prises simples sont branchées.

Source de l'image : Overloaded plug socket par The Clear Communication People, sur Flickr.

De la même façon, par exemple, pour programmer des graphismes en 3D, il est beaucoup plus facile de le faire en utilisant une API écrite dans un langage de haut niveau comme JavaScript ou Python, plutôt que d'essayer d'écrire du code bas niveau (comme C ou C++) qui contrôle directement le GPU de l'ordinateur ou d'autres fonctions graphiques.

Note : Voir aussi l'entrée du glossaire pour le terme API pour une description plus détaillée.

Les API JavaScript côté client

Le JavaScript côté client en particulier a de nombreuses API à sa disposition. Elles ne font pas partie du langage JavaScript lui-même, elles sont construites par-dessus JavaScript, offrant des super-pouvoirs supplémentaires à utiliser dans votre code. Elles se répartissent en deux catégories :

  • Les API web sont intégrées au navigateur web et permettent de rendre disponibles les données du navigateur et de son environnement afin de réaliser des choses complexes avec. Ainsi, l'API Web Audio fournit des constructions JavaScript pour manipuler des données audio dans le navigateur. On pourra utiliser cette API afin de récupérer une piste audio puis d'abaisser son volume, d'y appliquer des effets, etc. Sous le capot, c'est le navigateur qui s'occupe des couches plus complexes en code « bas niveau » (C++ ou Rust par exemple) afin de réaliser le traitement du signal. Là encore, cette complexité est masquée par l'abstraction offerte par l'API.
  • Les API tierces ne sont pas intégrées au navigateur par défaut, et vous devez généralement récupérer le code de l'API et des informations depuis un site web. Par exemple : l'API Twitter vous permet d'afficher vos derniers tweets sur votre site web. Elle fournit un ensemble de constructions que vous pouvez utiliser pour interroger le service Twitter et qui renvoie alors les informations demandées.

Une capture d'écran d'un navigateur ouvert sur la page d'accueil de Firefox. Il existe des API natives, construites dans le navigateur et disponibles par défaut. Il existe aussi des API tierces qui ne sont pas intégrées dans le navigateur et pour lesquelles il faut récupérer le code par ailleurs pour les utiliser.

Relations entre JavaScript, les API et autres outils JavaScript

Ci-dessus, nous avons indiqué ce qu'est une API JavaScript côté client et sa relation avec le langage JavaScript. Pour récapituler, clarifier, et apporter plus de précisions sur d'autres outils JavaScript qui existent :

JavaScript

Un langage de programmation de haut niveau intégré aux navigateurs, qui permet de mettre en œuvre des fonctionnalités sur les pages et applications web. Notez que JavaScript est également disponible dans d'autres environnements de programmation, tels que Node.js.

Les API web, fournies par le navigateur

Constructions intégrées dans le navigateur, situées au‑dessus du langage JavaScript, permettant une mise en œuvre plus facile de fonctionnalités.

Les API tierces

Constructions intégrées à des plateformes tierces (par exemple Twitter, Facebook) qui permettent d'utiliser certaines fonctionnalités de ces plateformes dans vos propres pages web (par exemple : afficher vos derniers tweets sur votre page web).

Les bibliothèques JavaScript

Habituellement, un ou plusieurs fichiers JavaScript contenant des fonctions personnalisées que vous pouvez attacher à votre page web pour accélérer ou activer l'écriture de fonctionnalités courantes. Des exemples incluent jQuery, Mootools et React.

Les frameworks JavaScript

Au‑dessus des bibliothèques, les frameworks JavaScript (par exemple Angular et Ember) sont plutôt des ensembles de HTML, CSS, JavaScript et autres technologies, que vous installez puis utilisez pour écrire une application web entière. La différence essentielle entre une bibliothèque et un framework est « l'inversion du contrôle ». Avec une bibliothèque, c'est la personne qui développe qui appelle les méthodes de la bibliothèque et exerce un contrôle. Avec un framework, le contrôle est inversé : c'est le framework qui appelle le code développé.

Que peuvent faire les API ?

Il existe de nombreuses API dans les navigateurs modernes. Elles permettent de réaliser plein de choses. Vous pouvez vous en faire une petite idée en jetant un coup d'œil à la page d'index des API web sur MDN.

Les API web du navigateur fréquemment utilisées

Voici les API web que vous rencontrerez le plus souvent (et que nous allons voir en détails dans ce module) :

Les API pour manipuler des documents chargés dans le navigateur

L'exemple le plus évident est l'API DOM (pour Document Object Model). Elle permet de manipuler le HTML et CSS : créer, supprimer et modifier du code HTML, appliquer de nouveaux styles à votre page dynamiquement, etc. Par exemple, chaque fois que vous voyez une fenêtre pop-up apparaître sur une page, ou qu'un nouveau contenu est affiché, c'est que le DOM est en action. Découvrez-en plus sur ces types d'API dans la rubrique Manipuler des documents.

Les API pour récupérer des données du serveur et mettre à jour une page web

Si vous avez juste besoin de mettre à jour une liste de produits ou afficher de nouveaux articles disponibles, le faire instantanément sans avoir à recharger toute la page du serveur peut rendre le site ou l'application beaucoup plus réactif et « accrocheur ». L'API Fetch est l'API principale pour cet usage (du code antérieur peut utiliser l'API XMLHttpRequest). Vous pourrez rencontrer le terme Ajax pour qualifier cette technique. Pour en savoir plus sur ces API, voir Récupérer des données du serveur.

Les API pour dessiner et manipuler des graphiques

Les plus populaires sont Canvas et WebGL. Elles permettent la mise à jour, par programmation, des pixels contenus dans un élément HTML <canvas> pour créer des scènes 2D et 3D. Par exemple, vous pouvez dessiner des formes comme des rectangles ou des cercles, importer une image sur le canevas, et lui appliquer un filtre sépia ou niveau de gris à l'aide de l'API Canvas ou encore créer une scène 3D complexe avec éclairage et textures en utilisant WebGL. De telles API sont souvent combinées avec d'autres API, par exemple window.requestAnimationFrame(), pour créer des boucles d'animation (faire des mises à jour continues de scènes) et ainsi créer des dessins animés et des jeux. Pour en savoir plus sur ces API, voir Dessiner des éléments graphiques.

Les API audio et vidéo

HTMLMediaElement, l'API Web Audio ou WebRTC permettent de faire des choses vraiment intéressantes avec du multimédia, telles que la création de contrôles personnalisés pour jouer de l'audio et vidéo, l'affichage de textes comme des légendes et des sous-titres, la récupération de vidéos depuis votre webcam pour l'afficher sur l'ordinateur d'une autre personne dans une visio‑conférence ou encore l'ajout d'effets sur des pistes audio (tels que le gain, la distorsion, la balance, etc.). Pour en savoir plus sur ces API, voir les API audio et vidéo.

Les API de périphérique

Elles permettent essentiellement de manier et récupérer des données à partir de périphériques modernes, de manière utile pour les applications web. Nous avons déjà parlé de l'API de géolocalisation accédant aux données d'emplacement de l'appareil afin que vous puissiez repérer votre position sur une carte.

Les API de stockage côté client

Elles permettent de stocker des données côté client et on peut donc créer une application qui enregistre son état entre les chargements de page, et peut-être même fonctionner lorsque le périphérique est hors ligne. Il existe un certain nombre d'options disponibles, par exemple le simple stockage nom/valeur avec l'API Web Storage, et le stockage plus complexe de données tabulaires avec l'API IndexedDB. Pour en savoir plus sur ces API, voir Stockage côté client.

API tierces courantes

Il y a une grande variété d'API tierces ; en voici quelques-unes des plus populaires que vous allez probablement utiliser tôt ou tard :

  • L'API Twitter vous permet d'afficher vos derniers tweets sur un site web.
  • Les API de cartographie comme Mapquest et Google Maps API vous permettent de réaliser toute sorte de cartes dans des pages web.
  • L'ensemble d'API de Facebook permet d'utiliser différentes parties de l'écosystème de Facebook dans votre application (par exemple pour la connexion avec un compte Facebook, la gestion des paiements ou de publicité, etc.).
  • Les API Telegram permettent d'intégrer le contenu de canaux Telegram sur un site web et de prendre en charge les bots.
  • L'API YouTube vous permet d'intégrer des vidéos YouTube sur votre site, de faire des recherches sur YouTube, de construire des listes de lecture, etc.
  • L'API Pinterest fournit des outils pour gérer des tableaux et épingles Pinterest et de les inclure à votre site web.
  • L'API Twilio fournit un ensemble d'outil pour intégrer des fonctionnalités d'appels audio et vidéo à une application et/ou d'envoyer des SMS/MMS.
  • L'API Mastodon permet de manipuler les fonctionnalités du réseau social Mastodon grâce à des programmes.

Comment les API fonctionnent-elles ?

Chaque API JavaScript a son fonctionnement propre. Elles partagent toutefois des fonctionnalités communes et des thèmes similaires.

Elles sont fondées sur des objets

Les API interagissent avec le code en utilisant un ou plusieurs objets JavaScript, qui servent de conteneurs pour les données utilisées par l'API (contenues dans les propriétés d'objet), et la fonctionnalité rendue disponible par l'API (contenue dans des méthodes d'objet).

Note : Si vous ne connaissez pas encore le fonctionnement des objets, vous devriez revenir en arrière et parcourir le module objets JavaScript avant de continuer.

Prenons comme exemple l'API Web Audio. Il s'agit d'une API assez complexe avec plusieurs objets. Voici les objets principaux :

AudioContext

Qui représente un graphe audio qui peut être utilisé afin de manipuler la lecture audio dans le navigateur et qui possède différentes méthodes et propriétés qui sont disponibles pour manipuler ce signal audio.

MediaElementAudioSourceNode (en-US)

Qui représente un élément <audio> contenant du son qu'on veut jouer et manipuler dans le contexte.

AudioDestinationNode (en-US)

Qui représente la destination de l'audio, c'est-à-dire le composant physique qui sera utilisé pour produire le son (il s'agit généralement des hauts-parleurs ou des écouteurs).

Alors comment ces objets interagissent-ils ? Si vous regardez notre exemple audio web (voir aussi le résultat), vous verrez le code HTML suivant :

html
<audio src="outfoxing.mp3"></audio>

<button class="paused">Lire</button>
<br />
<input type="range" min="0" max="1" step="0.01" value="1" class="volume" />

Pour commencer, nous incluons, un élément <audio> avec lequel nous intégrons un fichier MP3 dans la page. Nous n'incluons pas de contrôles par défaut du navigateur. Ensuite, nous incluons un <button> que nous utiliserons pour lire et arrêter la musique, et un élément <input> de type range, que nous utiliserons pour ajuster le volume de la piste en cours de lecture.

Ensuite, examinons le JavaScript de cet exemple.

Nous commençons par créer une instance AudioContext à l'intérieur de laquelle nous allons manipuler notre piste :

js
const AudioContext = window.AudioContext || window.webkitAudioContext;
const audioCtx = new AudioContext();

Ensuite, nous créons des constantes qui stockent les références à nos éléments <audio>, <button> et <input>, et nous utilisons la méthode AudioContext.createMediaElementSource() pour créer un MediaElementAudioSourceNode représentant la source de notre audio (ici, c'est l'élément <audio>) :

js
const audioElement = document.querySelector("audio");
const playBtn = document.querySelector("button");
const volumeSlider = document.querySelector(".volume");

const audioSource = audioCtx.createMediaElementSource(audioElement);

Ensuite, nous incluons deux gestionnaires d'évènements qui servent à basculer entre la lecture et la pause lorsque le bouton est pressé et à réinitialiser l'affichage au début lorsque la chanson est terminée :

js
// lecture/pause de l'audio
playBtn.addEventListener("click", function () {
  // vérifier si le contexte est en état de suspension (politique de lecture automatique)
  if (audioCtx.state === "suspended") {
    audioCtx.resume();
  }

  // si la piste est arrêtée, la lire
  if (this.getAttribute("class") === "paused") {
    audioElement.play();
    this.setAttribute("class", "playing");
    this.textContent = "Pause";
    // si une piste est en cours de lecture, l'arrêter
  } else if (this.getAttribute("class") === "playing") {
    audioElement.pause();
    this.setAttribute("class", "paused");
    this.textContent = "Lire";
  }
});

// si la piste se termine
audioElement.addEventListener("ended", function () {
  playBtn.setAttribute("class", "paused");
  playBtn.textContent = "Lire";
});

Note : Vous aurez peut-être remarqué que les méthodes play() et pause() utilisées pour lire et mettre en pause la piste ne font pas partie de l'API Web Audio ; elles font partie de l'API HTMLMediaElement. qui est différente mais étroitement liée.

Ensuite, nous créons un objet GainNode à l'aide de la méthode AudioContext.createGain(), qui peut être utilisé pour ajuster le volume de l'audio qui le traverse, et nous créons un autre gestionnaire d'évènements qui modifie la valeur du gain (volume) du graphique audio lorsque la valeur du curseur est modifiée :

js
const gainNode = audioCtx.createGain();

volumeSlider.addEventListener("input", function () {
  gainNode.gain.value = this.value;
});

La dernière chose à faire pour que cela fonctionne est de connecter les différents nœuds du graphe audio, ce qui est fait en utilisant la méthode AudioNode.connect() (en-US) disponible sur chaque type de nœud :

js
audioSource.connect(gainNode).connect(audioCtx.destination);

L'audio commence dans la source, qui est ensuite connectée au nœud de gain afin que le volume de l'audio puisse être ajusté. Le nœud de gain est ensuite connecté au nœud de destination afin que le son puisse être lu sur votre ordinateur (la propriété AudioContext.destination (en-US) représente ce qui est le AudioDestinationNode (en-US) par défaut disponible sur le matériel de votre ordinateur, par exemple vos haut-parleurs).

Elles ont des points d'entrée reconnaissables

Lorsque vous utilisez une API, vous devez vous assurer que vous savez où se trouve le point d'entrée de l'API. Dans l'API Web Audio, il s'agit de l'objet AudioContext, qui doit être utilisé pour effectuer toute manipulation audio quelle qu'elle soit.

L'API DOM (Document Object Model) a également un point d'entrée simple : ses fonctionnalités ont tendance à être trouvées accrochées à l'objet Document, ou à une instance d'un élément HTML que vous voulez modifier d'une manière ou d'une autre, par exemple :

js
const em = document.createElement("em"); // crée un nouvel élément em
const para = document.querySelector("p"); // référence à un élément p existant
em.textContent = "Coucou vous !"; // donne à em du contenu textuel
para.appendChild(em); // intègre em dans le paragraphe

L'API Canvas repose également sur l'obtention d'un objet de contexte à utiliser pour manipuler les choses, bien que dans ce cas, il s'agisse d'un contexte graphique plutôt que d'un contexte audio. Son objet de contexte est créé en obtenant une référence à l'élément <canvas> sur lequel vous voulez dessiner, puis en appelant sa méthode HTMLCanvasElement.getContext() :

js
const canvas = document.querySelector("canvas");
const ctx = canvas.getContext("2d");

Tout ce que nous voulons faire au canevas est ensuite réalisé en appelant les propriétés et les méthodes de l'objet contexte (qui est une instance de CanvasRenderingContext2D), par exemple :

js
Ball.prototype.draw = function () {
  ctx.beginPath();
  ctx.fillStyle = this.color;
  ctx.arc(this.x, this.y, this.size, 0, 2 * Math.PI);
  ctx.fill();
};

Note : Vous pouvez voir ce code en action dans notre démo de balles rebondissantes (voir le résultat en direct également).

Elles utilisent des évènements pour gérer les changements d'état

Nous avons déjà abordé les évènements plus tôt dans le cours dans notre article Introduction aux évènements, qui examine en détail ce que sont les évènements web côté client et comment ils sont utilisés dans votre code. Si vous n'êtes pas déjà familiarisé avec le fonctionnement des évènements de l'API web côté client, nous vous conseillons de lire cet article avant de poursuivre.

Certaines API web ne contiennent aucun évènement, mais la plupart en contiennent au moins quelques-uns. Les propriétés des gestionnaires qui nous permettent d'exécuter des fonctions lorsque des évènements se produisent sont généralement répertoriées dans notre matériel de référence dans des sections distinctes intitulées « Gestionnaires d'évènements ».

Nous avons déjà vu un certain nombre de gestionnaires d'évènements utilisés dans notre exemple d'API Web Audio ci-dessus :

js
// lecture/pause de l'audio
playBtn.addEventListener("click", function () {
  // vérifier si le contexte est en état de suspension (politique de lecture automatique)
  if (audioCtx.state === "suspended") {
    audioCtx.resume();
  }

  // si la piste est arrêtée, la lire
  if (this.getAttribute("class") === "paused") {
    audioElement.play();
    this.setAttribute("class", "playing");
    this.textContent = "Pause";
    // si une piste est en cours de lecture, l'arrêter
  } else if (this.getAttribute("class") === "playing") {
    audioElement.pause();
    this.setAttribute("class", "paused");
    this.textContent = "Lire";
  }
});

// si la piste se termine
audioElement.addEventListener("ended", function () {
  playBtn.setAttribute("class", "paused");
  playBtn.textContent = "Lire";
});

Elles disposent de mécanismes de sécurité supplémentaires adéquats

Les fonctionnalités des API web sont soumises aux mêmes considérations de sécurité que JavaScript et les autres technologies web (par exemple la règle de même origine), mais elles disposent parfois de mécanismes de sécurité supplémentaires. Par exemple, certaines des API web les plus modernes ne fonctionneront que sur des pages servies avec HTTPS, car elles transmettent des données potentiellement sensibles (par exemple l'API Service Workers et Push).

En outre, certaines API web demandent la permission à la personne pour être activée dès que des appels à ces interfaces sont effectués dans votre code. À titre d'exemple, l'API Notifications demande la permission à l'aide d'une boîte de dialogue contextuelle :

Une capture d'écran d'une boîte de dialogue de notification fournie par l'API Notifications du navigateur. Ici, le site web 'mdn.github.io' demande la permission de pousser des notifications. Une croix en haut à droite permet de fermer la boîte de dialogue et une liste déroulante permet de choisir les options. C'est l'option 'Toujours recevoir les notifications' qui est sélectionnée par défaut.

Les API Web Audio et HTMLMediaElement sont soumises à un mécanisme de sécurité pour la lecture automatique (en-US). Cela signifie essentiellement que vous ne pouvez pas lire automatiquement l'audio lorsqu'une page se charge : vous devez permettre aux personnes consultant le site de déclencher la lecture audio par le biais d'un contrôle comme un bouton. Cette mesure est prise parce que la lecture automatique de l'audio est généralement indésirable.

Note : Selon la rigueur du navigateur, ces mécanismes de sécurité peuvent même empêcher l'exemple de fonctionner localement, c'est-à-dire si vous chargez le fichier d'exemple local dans votre navigateur au lieu de l'exécuter à partir d'un serveur web. Au moment de la rédaction de ce document, notre exemple d'API Web Audio ne fonctionnait pas localement sur Google Chrome : nous avons dû le mettre sur GitHub pour qu'il fonctionne en étant servi depuis un serveur web.

Résumé

À ce stade, vous devriez avoir une bonne idée de ce que sont les API, de leur fonctionnement et de ce que vous pouvez faire avec dans votre code JavaScript. Vous avez probablement hâte de commencer à faire des choses amusantes avec des API spécifiques, alors allez-y ! Par la suite, nous verrons comment manipuler des documents avec le DOM (Document Object Model ou modèle objet de document en français).