• 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文件 

    、视频

    1.对在线视频的添加

    在各大网站打开一个视频,在下方的分享找到HTML代码,然后复制HTML代码到自己的代码中。

    2.添加本地视频

    <video src="" autoplay="autoplay"   loop="" ></video>    

    <audio src="" autoplay="autoplay" loop="loop"></audio>              

    autoplay为自动播放,loop为循环次数,引号内值为loop为无限循环,1为播放1次

    <video  width="450" height="262" controls="controls"> 
    <source src="image/2.mp4" type="video/mp4">
    Your browser does not support the video tag.
    </video>
    复制代码
     <video title="钢铁侠的变身视频" id="video1" width="400" style="margin-top:5px;">
        <source src="image/1.mp4" />  
        Your browser does not support HTML5 video.
      </video> <br /> 
       <button onclick="playPause()">播放/暂停</button> 
      <button onclick="makeBig()">大</button>
      <button onclick="makeNormal()">中</button>
      <button onclick="makeSmall()">小</button>
    <script>
    var myVideo=document.getElementById("video1");
    
    function playPause()
    { 
    if (myVideo.paused) 
      myVideo.play(); 
    else 
      myVideo.pause(); 
    } 
    
    function makeBig()
    { 
    myVideo.width=450; 
    } 
    
    function makeSmall()
    { 
    myVideo.width=350; 
    } 
    </script>
    复制代码

    、音频

    <audio controls="controls" autoplay="true" style="">
    <source src="cw.mp3" type="audio/mpeg">
    Your browser does not support the audio tag.
    </audio>

    <bgsound src="" loop="-1"   delay="" />

    delay表示摧迟,引号内数字为秒数。

     字幕滚动

    <marquee scrollamount="6" behavior="scroll" direction="left" align="middle" onmouseover=stop() onmouseout=start()>滚动字幕</marquee>

    2.各参数详解:
    a)scrollAmount。它表示速度,值越大速度越快。如果没有它,默认为6,建议设为1~3比较好。
    b)width和height,表示滚动区域的大小,width是宽度,height是高度。特别是在做垂直滚动的时候,一定要设height的值。
    c)direction。表示滚动的方向,默认为从右向左:←←←。可选的值有right、down、up。滚动方向分别为:right表示→→→,up 表示↑,down表示↓。
    d)scrollDelay,这也是用来控制速度的,默认为90,值越大,速度越慢。通常scrollDelay是不需要设置的。
    e)behavior。用它来控制属性,默认为循环滚动,可选的值有alternate(交替滚动)、slide(幻灯片效果,指的是滚动一次,然后停止 滚动)

    此种字幕滚动也适用于图片滚动

    、图片轮换

    复制代码
    <img id="obj"  src="three/c7.jpg"/>
    <script language="javascript" type="text/javascript" >
    var curIndex=0;
    //时间间隔(单位毫秒),每秒钟显示一张,数组共有5张图片放在Photos文件夹下。
    var timeInterval=1000;
    var arr=new Array();
    arr[0]="three/c7.jpg";
    arr[1]="three/c6.jpg";
    arr[2]="three/c8.jpg";
    arr[3]="three/c9.jpg";
    setInterval(changeImg,timeInterval);
    function changeImg()
    {
        var obj=document.getElementById("obj");
        if (curIndex==arr.length-1) 
        {
            curIndex=0;
        }
        else
        {
            curIndex+=1;
        }
        obj.src=arr[curIndex];
    }
    
     </script>
    复制代码

    2.js实现仿京东图片轮播效果,当鼠标划在窗口上面停止计时器,鼠标离开窗口,开启计时器,鼠标划在页签上面,停止计时器,手动切换

    HTML部分

    <style>
    *{
    margin:0px;
    padding:0px;
    list-style:none;           //这句话必须有,不然数字乱码
    }

    复制代码
    #flash{ 687px;height: 400px;left:0px;position: relative;cursor: pointer;}
        #pic li{position: absolute;top: 0;left: 0;z-index: 1;display: none;}
        #num{position: absolute;left: 40%;bottom: 10px;z-index: 2;cursor:default;}
        #num li{float: left; 20px;height: 20px;border-radius: 50%;background: #666;margin: 3px;line-height: 20px;text-align: center;color: #fff;cursor: pointer;}
        #num li.active{background: #f00;}
        .arrow{height: 60px; 30px;line-height: 60px;text-align: center;display: block;position: absolute;top:45%;z-index: 3;display: none;}
        .arrow:hover{background: rgba(0,0,0,0.7);}
        #flash:hover .arrow{display: block;}
        #left{left: 2%;}
        #right{right: 2%;}
    复制代码

    </style>

    复制代码
    <div id="flash">
     <ul id="pic">
         <li style="display:block"><img  src="images/h5.bmp" alt="" ></li>
          <li><img src="images/h7.png" style="550px; height:360px" alt="" ></li>
          <li><img src="images/h6.jpg" alt="" ></li>
          <li><img src="images/h3.jpg" alt="" ></li>
          <li><img src="images/h1.jpg" alt="" ></li>
           <li><img src="images/h2.jpg" alt="" ></li>
            <li><img src="images/h4.jpg" alt="" ></li>
        </ul>
        <ol id="num">
          <li class="active"> 1</li>
          <li>2</li>
          <li>3</li>
          <li>4</li>
          <li>5</li>
          <li>6</li>
          <li>7</li>
        </ol>
        <a href="javascript:;" class="arrow" id="left"><</a>
        <a href="javascript:;" class="arrow" id="right">></a> 
        </div>
    复制代码

    JavaScript部分

    复制代码
    function $(id) {
          return typeof id==='string'?document.getElementById(id):id;
        }
        window.onload=function(){
          var index=0;
          var timer=null;
          var pic=$("pic").getElementsByTagName("li");
          var num=$("num").getElementsByTagName("li");
          var flash=$("flash");
          var left=$("left");
          var right=$("right");
          //单击左箭头
          left.onclick=function(){
            index--;
            if (index<0) {index=num.length-1};
            changeOption(index);
          }
          //单击右箭头
          right.onclick=function(){
            index++;
            if (index>=num.length) {index=0};
            changeOption(index);
          }      
          //鼠标划在窗口上面,停止计时器
          flash.onmouseover=function(){
            clearInterval(timer);
          }
          //鼠标离开窗口,开启计时器
          flash.onmouseout=function(){
            timer=setInterval(run,2000)
          }
          //鼠标划在页签上面,停止计时器,手动切换
          for(var i=0;i<num.length;i++){
            num[i].id=i;
            num[i].onmouseover=function(){
              clearInterval(timer);
              changeOption(this.id);
            }
          }    
          //定义计时器
          timer=setInterval(run,2000)
          //封装函数run
          function run(){
            index++;
            if (index>=num.length) {index=0};
            changeOption(index);
          }
          //封装函数changeOption
          function changeOption(curindex){
            console.log(index)
            for(var j=0;j<num.length;j++){
              pic[j].style.display="none";
              num[j].className="";
            }
            pic[curindex].style.display="block";
            num[curindex].className="active";
            index=curindex;
          }
        }
    复制代码

    五 

    实现两个图层,平时第二个图层隐藏,鼠标触碰时第二个图层出现,另一个隐藏;鼠标离开恢复原样

    1.有且只有一个这种图层

    复制代码
    <style>
    #aa
    {
    100px;
    height:100px;
    left:50px;
    top:50px;
    background-color:#0FF;
    position:absolute;
    }
    #a
    {
        100px;
    height:100px;
    background-color: #F90;
    visibility:hidden;
    position:absolute;
    }
    </style>
    </head>
    
    <body>
    <div id="aa" onmouseover="over()" onmouseout="out()"><div id="a"> </div></div>
    <script>
    function over()
    {
        var aa =document.getElementById("a");
        aa.style.visibility="visible";
        }
        function out()
    {
        var aa =document.getElementById("a");
        aa.style.visibility="hidden";
        }
    </script>
    </body>
    </html>
    复制代码

    2.有多个一样的图层

    复制代码
    <style>
    #a
    {
        100%;
        height:415px;
        border:1px solid red;
        position:relative;}
    .aa
    {
        20%;
        height:200px;
        margin-left:4%;
        float:left;
        margin-top:5px;
        background-color:#0F6;
        position:relative;}
    .b
    {
        100%;
        height:200px;
        position:relative;
        background-color:#000;
        opacity:0.4;
        visibility:hidden;}
    #w
    {
        position:relative;
        top:-180px;
        visibility:hidden;
        }
    </style>
    </head>
    
    <body>
    <div id="a">
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    <div class="aa"><div class="b"></div></div>
    </div>
    </body>
    </html>
    <script>
    var all=document.getElementsByClassName("aa");
    for(var i=0;i<all.length;i++)
    {
        all[i].onmouseover=function(){this.firstChild.style.visibility="visible"}
        all[i].onmouseout=function(){this.firstChild.style.visibility="hidden"}
    }
    
    </script>
  • 相关阅读:
    Vue.js-项目目录结构解析
    Vue.js-创建Vue项目(Vue项目初始化)并不是用Webstrom创建,只是用Webstrom打开
    Node.js-npm安装包目录修改
    Node.js-Webstorm2018配置nodejs
    Node.js-ReferenceError: _filename is not defined
    cas系列-自定义异常提示(五)
    cas系列-cas登出(四)
    cas系列-cas REST协议(三)
    maven引入第三方jar包
    持续api管理翻译
  • 原文地址:https://www.cnblogs.com/1030351096zzz/p/6095078.html
Copyright © 2020-2023  润新知