向HTML中插入视频并兼容所有浏览器的方法

前端技术 2023/09/03 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=\"&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视频代码了。

本文地址:https://www.stayed.cn/item/6853

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。