J'écris un message de blog qui utilise plusieurs vidéos de YouTube et de Yahoo Video, mais je ne suis pas content de la durée pendant laquelle cela prend la page pour rendre. En dehors de l'utilisation d'une méthode Ajax-y pour charger les vidéos, y a-t-il des astuces qui rendraient la page chargée plus rapidement avec plusieurs vidéos de différentes sources? P>
5 Réponses :
Il n'y a aucune question à obtenir plusieurs vidéos de différents sites Web prend du temps. Avez-vous essayé d'obtenir une copie de ces vidéos, de la télécharger sur votre serveur Web et d'intégrer vos vidéos de cette façon? Il peut augmenter la vitesse de rendu de vos pages si les vidéos proviennent d'une source unique. P>
Merci pour la suggestion, Chutsu. C'est un bon point, mais malheureusement, je ne pense pas que ce sera possible d'obtenir des copies autres que d'intégrer les vidéos.
Pourquoi pas? Vous pouvez télécharger les vidéos Flash avec le plug-in Firefox "Flashgot" (Utilisez le bon ancien Google pour plus d'informations sur la manière de télécharger des vidéos 'FLV'). Et intégrer la vidéo Flv sur votre site web.
Je ne pense pas que tous les médias sur le même serveur le rendraient plus rapidement. La plupart des grands sites mettent des images et autres contenus statiques dans un autre hôte pour améliorer la vitesse. La raison principale est que les navigateurs ont un nombre maximal de connectes simultanées à un seul hôte. Et si le serveur YouTube peut être plus rapide que votre serveur.
Votre "méthode Ajax-y" sera le seul moyen de vous accélérer. Les grands sites vont utiliser un CDN et avoir une bonne mise en cache. Il n'y a aucun moyen de prendre beaucoup de fois que de grands fichiers ... p>
Garder l'objet ou la balise vidéo hors du code HTML, puis l'ajoutez-la après la charge de la page, améliorera les performances de charge de la page perçue. Peut-être échanger une image screengrab qui a la même taille que la vidéo éventuelle ... p>
Il est tôt pour la balise vidéo, mais il est possible que le délai d'initialisation soit éventuellement plus rapide que Flash, car il fait partie du navigateur et non un plug-in 3 tiers. p>
La majeure partie du temps de chargement vidéo dépend de la manière dont la vidéo a été codée / transférée qui est hors de votre contrôle, on dirait. P>
Le problème avec des vidéos YouTube intégrées est que le joueur lui-même doit être chargé. Vous pouvez ajouter des "contrôles = 2" dans l'URL du code d'intégration, mais qui ne ferait que des joueurs AS2 / 3 pour charger le joueur après avoir cliqué sur. P>
La solution de contournement Google+ a pour ce numéro n'est pas de charger le joueur du tout. Au lieu de cela, il charge une image miniature avec un bouton de lecture superposé. En cliquant sur le clic, l'image est remplacée par le joueur YouTube IFrame IFrame Incord Code et TI Charge et joue automatiquement. P>
Ceci peut être fait dans n'importe quel site en utilisant le simple JavaScript ci-dessous. https://skipser.googlecode.com/files/gplus-youtubeembed.js p>
Merci d'avoir travaillé à ce sujet. J'essaie votre solution à l'adresse suivante: ACLS.NET/Videos.htm en vain.
Le lien est cassé!
La solution Google Plus est le seul moyen d'améliorer les performances: chargez un talon d'image, puis chargez le lecteur complet lorsque l'utilisateur clique sur.
bâtiment de la solution de @boschaarun Voici la solution que j'utilise: P >
<style> div.video-container a img.playbutton {visibility: hidden; content:url("") } div.video-container a:hover .playbutton {visibility: visible;} </style> <div class="video-container"> <a style="position: relative; left: 0; top: 0;" href="https://www.youtube.com/watch?v=IJl2C8QPVjQ&rel=0"> <img src="//img.youtube.com/vi/IJl2C8QPVjQ/0.jpg" style="position: relative; top: 0; left: 0; width:100%; height:auto"> <img class="playbutton" style="position: absolute; top: 50%; left: 50%; margin-left:-38px; margin-top:-38px"> </a> </div> <script> $('.video-container').click( function(e){ e.preventDefault(); var imgURL = $(this).find("img").attr('src'); var rx = /\/vi\/([^\/]+)/ var arr = rx.exec(imgURL); var url = "//www.youtube.com/embed/"+arr[1]+"?rel=0&autoplay=1"; $(this).find("img").hide(); $(this).append('<iframe width="100%" height="315" src="'+url+'" frameborder="0" allowfullscreen></iframe>'); } ); </script>
Cette solution ne convient pas, il a de nombreux problèmes. Lorsque la superposition du bouton de lecture chargera la même vidéo plusieurs fois si vous cliquez dessus à nouveau et encore. Même vidéo va répéter
La solution consiste à "charger un talon d'image, puis chargez le lecteur complet lorsque l'utilisateur clique" et que est i> approprié. Vous devrez adapter la mise en œuvre si nécessaire pour éviter plusieurs clics ou autres cas latéraux.
Vous pouvez suivre les instructions de: https://varvy.com/pageSpeed/defer-videos.html
Juste au lieu d'utiliser le code comme celui-ci: p> Je changerais par: p> car, le SRC = " "pourrait être interprété comme src =" / "sur certains navigateurs, qui chargera une copie de votre site dans l'iframe ... p> p>