• 技术文章 >web前端 >html教程

    HTML中插入视频并兼容所有浏览器

    高洛峰高洛峰2017-03-02 15:03:08原创785
    向HTML中插入视频有两种方法,一种是古老的object标签,一种是html5中的video标签,前者兼容性相对好些,后者兼容性让人头疼 最常用的向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视频代码了。

    更多HTML中插入视频并兼容所有浏览器相关文章请关注PHP中文网!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:HTML 插入视频
    上一篇:定义span的最小高度没有效果的解决 下一篇:HTML列表标签dl、ul、ol 的使用
    20期PHP线上班

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• div+CSS浏览器兼容问题整理(IE6.0、IE7.0 ,ie8 , FireFox)_html/css_WEB-ITnose• ajax简单小例子_基于xml的实现• 浏览器得到地址栏的相关信息_html/css_WEB-ITnose• Codeforces Round#263(Div.2)_html/css_WEB-ITnose• bootstrap问题 高手在哪里?_html/css_WEB-ITnose
    1/1

    PHP中文网