如何检测HTML5视频标签支持的视频格式?

Cok*_*god 25 html javascript html5 cross-browser html5-video

我正在使用视频标签在HTML5中创建应用程序,在用户选择视频文件的应用程序中我播放该文件.这一切都发生在本地,因为我只链接到用户机器中的那个文件.

我想只允许浏览器可以播放的格式在我的应用程序中播放,并显示不支持格式的错误.问题是不同的浏览器可以播放不同的格式.

我知道我可以检查浏览器并将其与我知道它可以播放的格式相匹配,但是如果浏览器更新以支持其他格式怎么办?我将不得不使用新信息更新我的应用程序,同时用户将无法播放支持的格式.有没有办法检查支持的视频格式?

Wil*_*ill 47

您可以检查不同视频类型的编解码器HTMLVideoElement.prototype.canPlayType.还有一个很棒的HTML5特征检测库,Modernizr.

var testEl = document.createElement( "video" ),
    mpeg4, h264, ogg, webm;
if ( testEl.canPlayType ) {
    // Check for MPEG-4 support
    mpeg4 = "" !== testEl.canPlayType( 'video/mp4; codecs="mp4v.20.8"' );

    // Check for h264 support
    h264 = "" !== ( testEl.canPlayType( 'video/mp4; codecs="avc1.42E01E"' )
        || testEl.canPlayType( 'video/mp4; codecs="avc1.42E01E, mp4a.40.2"' ) );

    // Check for Ogg support
    ogg = "" !== testEl.canPlayType( 'video/ogg; codecs="theora"' );

    // Check for Webm support
    webm = "" !== testEl.canPlayType( 'video/webm; codecs="vp8, vorbis"' );
}
Run Code Online (Sandbox Code Playgroud)