Admin/Dev

19
Mars
2022

Pré-charger une vidéo en Javascript

Publié par sky

Pour une application HTML, il peut être intéressant de pré-charger une vidéo afin qu'elle puisse se lancer au moment où l'on souhaite, sans avoir à attendre qu'elle se charge depuis le serveur web.

Pour cela, il existe des mécaniques pour charger une vidéo, mais il y a des limitations. Il faut donc un peu tricher pour arriver à ses fins.

Voici ma solution pour arriver à charger une vidéo sans forcément la lire, avec du Javascript.

Commençons par créer un objet vidéo

maVideo = document.createElement('video');

indiquons lui le chemin vers la vidéo sur le serveur

maVideo.src = 'chemin/vers/ma/video.mp4';

ensuite, ajoutons le paramètre autoplay

maVideo.autoplay = true;

Même si votre vidéo de ne doit pas être lue dès son chargement, il est nécessaire d'ajouter ce paramètre. En effet, en l'indiquant, le navigateur va immédiatement démarrer le chargement de la vidéo, car elle doit être lue dès que possible.

Enfin, il faut placer la vidéo dans un espace de la page HTML, que l'on nommera pour l'exemple monEspaceVideo

document.getElementById('monEspaceVideo').appendChild(maVideo);

A partir de là, votre vidéo va se charger automatiquement. A vous de la cacher si nécessaire, ou d'en faire ce que vous voulez.

Dans le cadre d'une application, il peut être intéressant de savoir quand la vidéo est entièrement chargée et donc disponible pour une lecture. De plus, si l'on ne souhaite pas que la lecture soit automatique, alors il faut intervenir.

Pour cela on va ajouter un événement qui faire cela pour nous, qui ressemblerait à cela

maVideo.addEventListener("canplaythrough", function() {
}, false);

Commençons par mettre en pause la vidéo

maVideo.addEventListener("canplaythrough", function() {
    maVideo.pause();
}, false);

puis vous pouvez envoyer l'information à votre application, avec une fonction que vous prévoirez. Ici, pour l'exemple nous allons définir une application nommée monApp, et une fonction videoLoadComplete.

maVideo.addEventListener("canplaythrough", function() {
    maVideo.pause();     monApp.videoLoadComplete();
}, false);

A ce moment, on pourrait croire que l'on a fini. Techniquement, c'est bien le cas. Cependant, certains navigateurs ont tendance à déclencher plusieurs fois l'événement, ce qui peut perturber l'application. Nous allons donc ajouter une petite subtilité qui consiste à retirer l'événement après le premier déclenchement.

Pour cela, faites bien attention, il faut transformer la fonction anonyme que l'on donne à l'événement, en fonction nommée pour pouvoir la récupérer plus tard.

maVideo.addEventListener("canplaythrough", function onVideoPreload() {
    maVideo.pause();     monApp.videoLoadComplete();     maVideo.removeEventListener("canplaythrough", onVideoPreload);
}, false);

Et voilà, le tour est joué !

Voici le script dans son intégralité

maVideo = document.createElement('video');
maVideo.src = 'chemin/vers/ma/video.mp4';
maVideo.autoplay = true;
document.getElementById('monEspaceVideo').appendChild(maVideo);
maVideo.addEventListener("canplaythrough", function onVideoPreload() {
    maVideo.pause();     monApp.videoLoadComplete();     maVideo.removeEventListener("canplaythrough", onVideoPreload);
}, false);
 
 
Commentaires
Commentaire de Greg le 29 Décembre 2024 à 03:50

Bonjour.
Désolé mais rien ne fonctionne.
On ne sait pas ce qu'est maVideo.pause, pas plus que monApp

 
Commentaire de sky le 29 Décembre 2024 à 10:18

Bonjour Greg,
maVideo est l'objet Javascript qui contient la vidéo, dès le début de son chargement, nous lui disons de se mettre en pause, afin que la vidéo ne se joue pas. Le but étant de pré-charger la vidéo, sans la jouer.
Quant à l'objet monApp, c'est ici un objet qui n'existe que virtuellement. Le code proposé ici n'a aucun intérêt seul. Il est fait pour s'intégrer au sein d'une application plus complète. L'indication monApp.videoLoadComplete(); n'est la que pour indiquer à l'application que la vidéo est chargée, et qu'elle pourra s'en servir dès qu'elle en a besoin. Vous pouvez remplacer "monApp" par le nom de votre application et "videoLoadComplete()" par la fonction qui indique à l'application que la vidéo est prête à l'emploi.
En espérant que cela éclaircisse vos points d'ombre.

 

 

Poster un commentaire
En postant sur skymac.org, je m'engage à être courtois et à ce que mon message soit pertinent avec le sujet de l'article.
En outre, j'accepte, sans condition, que mon message soit refusé et supprimé si ces règles ne sont pas appliquées.
Ouvrir le panneau de gestion des cookies
Fermer le panneau
Ce site utilise des cookies pour assurer son bon fonctionnement. Il utilise aussi des cookies issues de services tiers permettant de proposer des fonctionnalités avancées. À tout moment, vous pouvez choisir quels services vous souhaitez activer ou refuser, afin de retirer votre consentement quant à l'utilisation des cookies.
 
Personnalisation des services
Vous êtes libre de choisir quels services vous souhaitez activer. En autorisant ces services tiers, vous acceptez le dépôt et la lecture de cookies et l'utilisation de technologies de suivi nécessaires à leur bon fonctionnement. En retirant votre consentement pour certains de ces services, certaines fonctionnalités du site peuvent ne plus fonctionner.
Navigation du site  En savoir plus
Le site écrit un cookie de session permettant son bon fonctionnement et aidant à la navigation. Il ne peut être désactivé.
Utilisation : 1 cookie, enregistre l'identifiant de la session.
Durée de vie : Le cookie est présent pendant toute la session sur le site. Il devient obsolète après 24 minutes d'inactivité.
Obligatoire
Popup Média
Afficher des vidéos depuis Yoube ou Dailymotion.
 
Tout accepter Tout refuser Gérer