是否可以在 iframe 上停止/暂停视频?

Posted

技术标签:

【中文标题】是否可以在 iframe 上停止/暂停视频?【英文标题】:Is it possible to stop/pause video on iframe? 【发布时间】:2015-09-10 13:50:35 【问题描述】:

这是视频

 <iframe id="vt"  autoplay="false"  src="http://cache4.asset-cache.net/xd/468140002.mp4?v=1&c=IWSAsset&k=2&d=72990B68305E4FDFEE95B69A879131BCD6D7111452E48A17C03F8342D660D5A451EBC1DEC2A827C9&b=RTdG" frameborder="0" allowfullscreen></iframe> 

我想停止或暂停它,可以吗?只想坚持 iframe

http://jsfiddle.net/karimkhan/2Lgxk5h3/7/

js/jquery 中的任何函数都可以吗?

【问题讨论】:

当 iframe 不在同一个域中时,您无法使用脚本访问 iframe。 (搜索跨站点脚本 XSS)。我曾经尝试通过触发 iFrame 上的空格键事件(这应该使视频停止)来做到这一点,但我无法让它工作并放弃了。 【参考方案1】:

是的,您可以从 iframe 访问您的视频,但这仅适用于帧源位于同一域中的情况。如果它来自不同的域,跨站点脚本 (XSS) 保护将启动。

我想您正在播放您域中的视频,(嵌入式 iframe url 域与页面域大部分相同)。

测试:

到这里: http://cache4.asset-cache.net/

并在控制台中运行此代码:

var video = undefined;
//define iframe in html
ifrm = document.createElement("IFRAME"); 
ifrm.setAttribute("src", "http://cache4.asset-cache.net/xd/468140002.mp4?v=1&c=IWSAsset&k=2&d=72990B68305E4FDFEE95B69A879131BCD6D7111452E48A17C03F8342D660D5A451EBC1DEC2A827C9&b=RTdG"); 
ifrm.setAttribute("id", "vt");
ifrm.setAttribute("width","420");
ifrm.setAttribute("autoplay","false"); 
ifrm.setAttribute("height","345");
document.body.appendChild(ifrm); 

//iframe load event
ifrm.onload = function() 
    var btnPlay = document.createElement("BUTTON");
    btnPlay.setAttribute("onclick", "play();");
    var t1 = document.createTextNode("PLAY ME");       
    btnPlay.appendChild(t1);                               
    document.body.appendChild(btnPlay);

    var btnPause = document.createElement("BUTTON");        
    btnPause.setAttribute("onclick", "pause();");
    var t2 = document.createTextNode("PAUSE ME");      
    btnPause.appendChild(t2);                              
    document.body.appendChild(btnPause);

    video = document.getElementById("vt").contentWindow.document.body.getElementsByTagName('video')[0];



//play stop methods
function play()

  if (video != undefined)
    video.play();
  return false;


function pause()

  if (video != undefined)
    video.pause();
  return false;

结论如果您的 iframe 源与您的域不同,则您无法从帧控制视频。以上是跨站脚本不影响您时如何控制视频。

【讨论】:

【参考方案2】:

我使用以下代码在 iframe 中播放/暂停视频:

播放:

var frames = document.getElementsByTagName('iframe');var t=1;
for (var i in frames)
  $(frames[i]).contents().find('video')[0].play();
  if(t===frames.length)break;
                  t++;

暂停:

var frames = document.getElementsByTagName('iframe');var t=1;
for (var i in frames)
  $(frames[i]).contents().find('video')[0].pause();
  if(t===frames.length)break;
                  t++;

【讨论】:

请添加更多详细信息以扩展您的答案,例如工作代码或文档引用。【参考方案3】:

我正在为您使用此 html 和 JS 代码停止、播放暂停视频库中的视频提供解决方案。

    <script>
      var slideIndexVid = 1;
      showSlidesVid(slideIndexVid);
      
      function plusSlidesVid(n) 

        
        showSlidesVid(slideIndexVid += n);
      
      
      function currentSlideVid(n) 
        showSlidesVid(slideIndexVid = n);
      
      
      function showSlidesVid(n) 
        var i;
        var slidesVid = document.getElementsByClassName("vid-slides");
        var dotsVid = document.getElementsByClassName("dot-vid");

       
        $('#vidS1')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        $('#vidS2')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        $('#vidS3')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        $('#vidS4')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        $('#vidS5')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        $('#vidS6')[0].contentWindow.postMessage('"event":"command","func":"' + 'pauseVideo' + '","args":""', '*');
        
        
        if (n > slidesVid.length) slideIndexVid = 1
        if (n < 1) slideIndexVid = slidesVid.length
        for (i = 0; i < slidesVid.length; i++) 
          slidesVid[i].style.display = "none";
        
        for (i = 0; i < dotsVid.length; i++) 
            dotsVid[i].className = dotsVid[i].className.replace(" active-vid", "");
        
        
        slidesVid[slideIndexVid-1].style.display = "block";
        dotsVid[slideIndexVid-1].className += " active-vid";      
        
    </script>
<div class="video-container">
      <h2>Our Demo Sessions</h2>
      <div class="vid-slides">
        <iframe id="vidS1" src="https://www.youtube.com/embed/PGW3lgbGFc8?rel=0&&enablejsapi=1" frameborder="0" enablejsapi allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>
      <div class="vid-slides">
        <iframe id="vidS2" src="https://www.youtube.com/embed/oolJWcOhHCw?rel=0&&enablejsapi=1" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>
      <div class="vid-slides">
        <iframe id="vidS3" src="https://www.youtube.com/embed/9MO1aY1xC80?rel=0&&enablejsapi=1" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>
      <div class="vid-slides">
        <iframe id="vidS4" src="https://www.youtube.com/embed/q5jEY92Amgw?rel=0&&enablejsapi=1" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>
      <div class="vid-slides">
        <iframe  id="vidS5" src="https://www.youtube.com/embed/VLUl3NgQY1A?rel=0&&enablejsapi=1" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>
      <div class="vid-slides">
        <iframe id="vidS6" src="https://www.youtube.com/embed/rw8GhqZaNHE?rel=0&&enablejsapi=1" frameborder="0" allow="accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
      </div>

      <a class="prev-video" onclick="plusSlidesVid(-1)"><</a>
      <a class="next-video" onclick="plusSlidesVid(1)">></a>
      
      <div style="text-align:center">
        <span class="dot-vid" onclick="currentSlideVid(1)"></span> 
        <span class="dot-vid" onclick="currentSlideVid(2)"></span> 
        <span class="dot-vid" onclick="currentSlideVid(3)"></span>
        <span class="dot-vid" onclick="currentSlideVid(4)"></span> 
        <span class="dot-vid" onclick="currentSlideVid(5)"></span> 
        <span class="dot-vid" onclick="currentSlideVid(6)"></span>
      </div> 
    </div>

【讨论】:

【参考方案4】:

我遇到了同样的问题,花了几个小时后,我试图在 iframe 中暂停本地/一个域(S3 服务器)中的视频。我知道,如果我们从本地或一个域获取视频而不是使用视频标签,它会提供更多控制,我已经将 iframe 用于 youtube 视频

这里是代码,这里默认控制是暂停

            <video width='200' height='180' src="" style='position:absolute;width:100%;height:100%;left:0' controls>
            </video>

启用自动播放

        <video width='200' height='180' src="" style='position:absolute;width:100%;height:100%;left:0' controls autoplay>
        </video>

这将节省您的时间并为您提供更多控制权

【讨论】:

这不是解决方案,解决方案是明确回答问题

以上是关于是否可以在 iframe 上停止/暂停视频?的主要内容,如果未能解决你的问题,请参考以下文章

Youtube video iframe API - 如何在失去焦点时暂停视频?

播放另一个嵌入的 YouTube iframe 时停止

使用播放/暂停/停止按钮控制 Flash 视频的声音

灯箱关闭时停止并播放 Iframe 视频

暂停视频不会停止 html5 视频标签中的音频

单击链接 javascript 时停止所有播放 iframe 视频