HTML <video loop =“”> - 多次下载</video>

时间:2013-08-28 06:11:18

标签: html5 google-chrome video

我正在尝试将视频设置为页面中的背景。问题是,我有一个并触发1次视频下载,然后当它完成时再次开始播放视频,但它也会再次下载。

好像这是一件小事,在第五次迭代之后,它就停止播放视频了。

我现在正在Ubuntu 13.04上使用Chrome 30.0.1599.14 dev


这是截图

Dev tools with the video requests

有关如何阻止此行为的任何建议?

3 个答案:

答案 0 :(得分:4)

 <style type="text/css">
body { background: url(demo.jpg) center; 
background-size: 300%;
width:100%;
height:150px;}
video { display: block; }
video#bgvid {
position: fixed;
top: 50%;
left: 50%;
min-width: 100%;
min-height: 100%;
width: auto;
height: auto;
z-index: -100000;
-webkit-transform: translateX(-50%) translateY(-50%);
transform: translateX(-50%) translateY(-50%);

}
@media screen and (max-device-width: 800px) {
body { background: url(demo.jpg) #000 no-repeat center center fixed; }
#bgvid { display: none; }
}
</style>
<script type="text/javascript">
//if it is not already in local storage
if (localStorage.getItem("demo") === null){
 //make request for file
var oReq = new XMLHttpRequest();
oReq.open("POST", "http://LINK_TO_demo.mp4", true);
 // arraybuffer needed for binary file 
oReq.responseType = "arraybuffer";
 // once loaded 
oReq.onload = function(oEvent) {
 // Convert to Blob Object
var blob = new Blob([oReq.response], {type: "video/mp4"});
var reader = new FileReader();
reader.readAsDataURL(blob);
reader.onload = function(e) {
var dataURL = reader.result;
localStorage.setItem("demo", dataURL);
// reload or add document ready function.
location.reload();
}
oReq.send();}} 
var videlem = document.createElement("video");
videlem.autoplay = true;
videlem.loop = true;
videlem.poster = "demo.jpg";
videlem.id = "bgvid";
var sourceMP4 = document.createElement("source"); 
sourceMP4.type = "video/mp4";
sourceMP4.src = localStorage.getItem("demo");
sourceMP4.autoPlay = true;
videlem.appendChild(sourceMP4);
document.body.appendChild(videlem);    
</script>

这将使其播放速度更快并将视频存储在本地存储中,因此不再向服务器发出请求。

答案 1 :(得分:1)

我遇到了同样的问题,并在互联网上寻找解决方案。 我知道这是一个3岁的帖子,但它可能会帮助遇到这个问题的人。 在我的情况下,我们在循环中有一个+ - 24mb .mp4文件,chrome在每个循环上重载了视频。我稍微压缩了视频并将视频转换为.webm。文件大小减少到4.5mb,问题就消失了。

编辑:好像它与文件大小有关。使用4.5mb .mp4也不会出现此问题。

答案 2 :(得分:0)

解决此问题的唯一方法是将文件加载到本地存储或其他东西。上面的例子