17

我即将尝试在 HTML5 中完全预加载视频。我使用该属性preload=auto,但它不会预加载整个视频...在 Chrome 中,视频仅预加载了 2%,而在 Safari 中则为 50% 左右...

是否可以使用 javascript 强制执行完整的预加载视频?

4

1 回答 1

11
function addSourceToVideo(element, src, type) {    
    var source = document.createElement('source');    
    source.src = src;    
    source.type = type;    
    element.appendChild(source);    
}

var video;       
$(document).ready(function(){    
    video = document.getElementsByTagName('video')[0];    
    addSourceToVideo( video, "http://your-server.com/clip.ogv", "video/ogv");    
    addSourceToVideo( video, "http://your-server.com/clip.mp4", "video/mp4");    
    video.addEventListener("progress", progressHandler,false);       
});

progressHandler = function(e) {    
    if( video.duration ) {    
        var percent = (video.buffered.end(0)/video.duration) * 100;    
        console.log( percent );    
        if( percent >= 100 ) {    
            console.log("loaded!");    
        }    
        video.currentTime++;    
    }    
}
于 2014-11-18T04:27:44.737 回答