向HTML中插入视频,兼容全部浏览器
最经常使用的向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="&MM_ComponentVersion=1&skinName=public/swf/Clear_Skin_3&streamName=public/video/test&autoPlay=false&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版本号,由于server的原因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="&MM_ComponentVersion=1&skinName=public/swf/Clear_Skin_3&streamName=public/video/test&autoPlay=false&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>
到此为止。就能够编写兼容全部浏览器的HTML视频代码了。