J'ai une liste de vidéos iframe dans ma page Web.
<iframe width="520" height="360" src="http://www.youtube.com/embed/2muxrT5_a6E" frameborder="0" allowfullscreen></iframe>
<iframe width="520" height="360" src="http://www.youtube.com/embed/2muxrT5_a6E" frameborder="0" allowfullscreen></iframe>
<iframe width="520" height="360" src="http://www.youtube.com/embed/2muxrT5_a6E" frameborder="0" allowfullscreen></iframe>
<a href="#" class="close">Stop all videos</a>
Je dois arrêter de lire toutes les vidéos iframe en cliquant sur le lien Stop all videos
. Comment puis je faire ça?
Essayez de cette façon,
<script language="javascript" type="text/javascript" src="jquery-1.8.2.js"></script>
<script language="javascript" type="text/javascript">
$(function(){
$('.close').click(function(){
$('iframe').attr('src', $('iframe').attr('src'));
});
});
</script>
Cela devrait arrêter la lecture de toutes les vidéos dans tous les iframes de la page:
$("iframe").each(function() {
var src= $(this).attr('src');
$(this).attr('src',src);
});
Arrêter signifie mettre en pause et régler la vidéo sur le temps 0:
$('iframe').contents().find('video').each(function ()
{
this.currentTime = 0;
this.pause();
});
Ce code jQuery fera exactement cela.
Pas besoin de remplacer l'attribut src et de recharger à nouveau la vidéo.
Petite fonction que j'utilise dans mon projet:
function pauseAllVideos()
{
$('iframe').contents().find('video').each(function ()
{
this.pause();
});
$('video').each(function ()
{
this.pause();
});
}
J'ai édité le code ci-dessus un peu et le suivant a fonctionné pour moi .......
<script>
function stop(){<br/>
var iframe = document.getElementById('myvid');<br/>
var iframe1 = document.getElementById('myvid1');<br/>
var iframe2 = document.getElementById('myvid2');<br/>
iframe.src = iframe.src;<br/>
iframe1.src=iframe1.src;<br/>
iframe2.src=iframe2.src;<br/>
}<br/>
</script>
Recharger tous les iframes juste pour les arrêter est une idée terrible. Vous devriez obtenir un avantage de ce qui vient avec HTML5.
Sans utiliser la bibliothèque iframe_API de YouTube; vous pouvez simplement utiliser:
var stopAllYouTubeVideos = () => {
var iframes = document.querySelectorAll('iframe');
Array.prototype.forEach.call(iframes, iframe => {
iframe.contentWindow.postMessage(JSON.stringify({ event: 'command',
func: 'stopVideo' }), '*');
});
}
stopAllYouTubeVideos();
ce qui arrêtera toutes les vidéos youtubes iframe.
Vous pouvez utiliser ces mots clés pour démarrer/arrêter/suspendre les vidéos youtube incorporées:
stopVideo
playVideo
pauseVideo
Consultez le lien ci-dessous pour la démonstration en direct:
https://codepen.io/mcakir/pen/JpQpwm
$("#close").click(function(){
$("#videoContainer")[0].pause();
});
Vous pouvez modifier ce code avec une itération
/**
* Stop an iframe or HTML5 <video> from playing
* @param {Element} element The element that contains the video
*/
var stopVideo = function ( element ) {
var iframe = element.querySelector( 'iframe');
var video = element.querySelector( 'video' );
if ( iframe ) {
var iframeSrc = iframe.src;
iframe.src = iframeSrc;
}
if ( video ) {
video.pause();
}
};
PROPRIÉTAIRE: https://Gist.github.com/cferdinandi/9044694 Également posté ici (par moi): comment détruire complètement la fenêtre modale bootstrap
Rechargez à nouveau tous les iframes pour arrêter les vidéos
<a href="#" class="close" onclick="stop();">Stop all videos</a>
function stop(){
var iframe = document.getElementById('youriframe');
iframe.src = iframe.src;
}