向html中插入视频并兼容所有浏览器的方法
2014-10-27来源:易贤网

最常用的向html中插入视频的方法有两种,一种是古老的<object></object>标签,一种是html5中的<video></video>标签。

前者的兼容性没得说,但是使用起来不太方便,后者使用起来很方便,但是兼容性让人头疼。

虽然后者兼容性存在很多问题,但是因为使用很方便,符合未来网页设计发展的趋势,因此我们以后者为主要的插入视频的方法,因为它兼容性的问题,前者作为辅助。

示例如下:

代码如下:

<video width=602px height=345px controls=controls>

<source src=public/video/test.mp4 type=video/mp4></source>

<source src=public/video/test.ogg type=video/ogg></source>

your browser does not support the video tag

</video>

当前,video 元素支持三种视频格式:

格式 ie firefox opera chrome safari

ogg no 3.5+ 10.5+ 5.0+ no

mpeg 4 9.0+ no no 5.0+ 3.0+

webm no 4.0+ 10.6+ 6.0+ no

ogg = 带有 theora 视频编码和 vorbis 音频编码的 ogg 文件

mpeg4 = 带有 h.264 视频编码和 aac 音频编码的 mpeg 4 文件

webm = 带有 vp8 视频编码和 vorbis 音频编码的 webm 文件

注:格式必须符合上面三条详细要求,比如mpeg 4,必须是h.264视频和aac音频。

在这种情况下,如果视频格式正确,大部分浏览器的兼容性结果我们还算满意,但是ie678不支持它,并且人家的用户至今在中国还是十分庞大的群体,我们就必须想到另外一个解决方案支持它们:

代码如下:

<object classid=clsid:d27cdb6e-ae6d-11cf-96b8-444553540000 width=624 height=351 style=margin-top: -10px;margin-left: -8px; id=flvplayer1>

<param name=movie value=flvplayer_progressive.swf />

<param name=quality value=high />

<param name=wmode value=opaque />

<param name=scale value=noscale />

<param name=salign value=lt />

<param name=flashvars value=&amp;mm_componentversion=1&amp;skinname=public/swf/clear_skin_3&amp;streamname=public/video/test&amp;autoplay=false&amp;autorewind=false />

<param name=swfversion value=8,0,0,0 />

<!-- 此 param 标签提示使用 flash player 6.0 r65 和更高版本的用户下载最新版本的 flash player。如果您不想让用户看到该提示,请将其删除。 -->

<param name=expressinstall value=expressinstall.swf />

</object>

这里面引入了一些文件,除了flv格式的视频,还有几个swf或js文件,都是用dw软件生成的,不想研究<object></object>标签的朋友去dw软件生成就行,如果可以巧妙的融合

这两段代码就可以得到兼容所有主流浏览器的终极代码了。

于是我们可以这样:

用jquery判断浏览器是否为ie(不用判断具体ie版本,因为服务器的原因ie很可能高版本也不通过,暂且ie全部用<object></object>标签),根据版本加载不同的标签,代码如下:

代码如下:

<script>

if($.browser.msie){

document.write('<object classid=clsid:d27cdb6e-ae6d-11cf-96b8-444553540000 width=624 height=351 style=margin-top: -10px;margin-left: -8px; id=flvplayer1>'+

'<param name=movie value=flvplayer_progressive.swf />'+

'<param name=quality value=high />'+

'<param name=wmode value=opaque />'+

'<param name=scale value=noscale />'+

'<param name=salign value=lt />'+

'<param name=flashvars value=&amp;mm_componentversion=1&amp;skinname=public/swf/clear_skin_3&amp;streamname=public/video/test&amp;autoplay=false&amp;autorewind=false />'+

'<param name=swfversion value=8,0,0,0 />'+

'<!-- 此 param 标签提示使用 flash player 6.0 r65 和更高版本的用户下载最新版本的 flash player。如果您不想让用户看到该提示,请将其删除。 -->'+

'<param name=expressinstall value=expressinstall.swf />'+

'</object>');

}else{

document.write('<video width=602px height=345px controls=controls>'+

'<source src=public/video/test.mp4 type=video/mp4></source>'+

'<source src=public/video/test.ogg type=video/ogg></source>'+

'your browser does not support the video tag'+

'</video>');

}

</script>

不要忘记在写这段代码之前引入jquery文件

到此为止,就可以编写兼容所有浏览器的html视频代码了。

更多信息请查看IT技术专栏

推荐信息