zoukankan      html  css  js  c++  java
  • H5 常用标签梳理

    H5功能很强大,仅仅通过一些标签就可以实现音乐播放,视频播放等功能,或者是画图,拖拽等,今天我们来梳理一下这些简单却又高大上的标签:

    1、video元素

     video 元素允许多个 source 元素。source 元素可以链接不同的视频文件,其中vedio标签之间插入的内容是供不支持 video 元素的浏览器显示的

    <!DOCTYPE html> 
    <html> 
    <body> 
    
    <div style="text-align:center;">
      <button onclick="playPause()">播放/暂停</button> 
      <button onclick="makeBig()"></button>
      <button onclick="makeNormal()"></button>
      <button onclick="makeSmall()"></button>
      <br /> 
      <video id="video1" width="420" style="margin-top:15px;">
        <source src="/example/html5/mov_bbb.mp4" type="video/mp4" />
        <source src="/example/html5/mov_bbb.ogg" type="video/ogg" />
        Your browser does not support HTML5 video.
      </video>
    </div> 
    
    <script type="text/javascript">
    var myVideo=document.getElementById("video1");
    
    function playPause()
    { 
    if (myVideo.paused) 
      myVideo.play(); 
    else 
      myVideo.pause(); 
    } 
    
    function makeBig()
    { 
    myVideo.width=560; 
    } 
    
    function makeSmall()
    { 
    myVideo.width=320; 
    } 
    
    function makeNormal()
    { 
    myVideo.width=420; 
    } 
    </script> 
    
    </body> 
    </html>

    2、audio元素
    audio元素实现在浏览器中播放音频,<audio> 与 </audio> 之间插入的内容是供不支持 audio 元素的浏览器显示的,音频文件最好是MP3 或 Wav 类型:

    <!DOCTYPE HTML>
    <html>
    <body>
    
    <audio controls="controls">
      <source src="/i/song.ogg" type="audio/ogg">
      <source src="/i/song.mp3" type="audio/mpeg">
    Your browser does not support the audio element.
    </audio>
    
    </body>
    </html>

    3、draggable,通过draggable属性和ondragstart 和 setData()方法实现拖拽

    <!DOCTYPE HTML>
    <html>
    <head>
    <style type="text/css">
    #div1 {width:198px; height:66px;padding:10px;border:1px solid #aaaaaa;}
    </style>
    <script type="text/javascript">
    function allowDrop(ev)
    {
    ev.preventDefault();
    }
    
    function drag(ev)
    {
    ev.dataTransfer.setData("Text",ev.target.id);
    }
    
    function drop(ev)
    {
    ev.preventDefault();
    var data=ev.dataTransfer.getData("Text");
    ev.target.appendChild(document.getElementById(data));
    }
    </script>
    </head>
    <body>
    
    <p>请把 W3School 的图片拖放到矩形中:</p>
    
    <div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
    <br />
    <img id="drag1" src="/i/eg_dragdrop_w3school.gif" draggable="true" ondragstart="drag(event)" />
    
    </body>
    </html>
    • 调用 preventDefault() 来避免浏览器对数据的默认处理(drop 事件的默认行为是以链接形式打开)
    • 通过 dataTransfer.getData("Text") 方法获得被拖的数据。该方法将返回在 setData() 方法中设置为相同类型的任何数据。
    • 被拖数据是被拖元素的 id ("drag1")
    • 把被拖元素追加到放置元素(目标元素)中

    4、Canvas元素

    通过js代码将绘制的东西呈现到canvas元素中,可以实现划线,画圆,画图片到画布上:

    <!DOCTYPE HTML>
    <html>
    <body>
    
    <canvas id="myCanvas" width="200" height="100" style="border:1px solid #c3c3c3;">
    Your browser does not support the canvas element.
    </canvas>
    
    <script type="text/javascript">
    
    var c=document.getElementById("myCanvas");
    var cxt=c.getContext("2d");
    var img=new Image()
    img.src="/i/eg_flower.png"
    cxt.drawImage(img,0,0);
    
    </script>
    
    </body>
    </html>

    5、svg元素

    与其他图像格式相比(比如 JPEG 和 GIF),使用 SVG 的优势在于:

    • SVG 图像可通过文本编辑器来创建和修改
    • SVG 图像可被搜索、索引、脚本化或压缩
    • SVG 是可伸缩的
    • SVG 图像可在任何的分辨率下被高质量地打印
    • SVG 可在图像质量不下降的情况下被放大
    <!DOCTYPE html>
    <html>
    <body>
    
    <svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="190">
       <polygon points="100,10 40,180 190,60 10,60 160,180"
       style="fill:red;stroke:blue;stroke-3;fill-rule:evenodd;" />
    </svg>
     
    </body>
    </html>

     6、未完待续

    参考W3C规范:http://www.w3school.com.cn/html5/html_5_video.asp

  • 相关阅读:
    [Go] 理解(*interface{})(nil) 赋值的变量是否为nil
    [Linux] 理解CPU缓存的伪共享问题
    [MySQL] 理解InnoDB并发高的原因
    [Go] 理解计算机负数的表示以及整数范围
    [Go]理解golang项目性能分析工具trace
    [Go]理解golang项目性能分析工具PProf
    [Go] 理解切片slice扩容
    [javascript]解决多个版本的jquery库或者$冲突
    [Linux] 理解Reactor 模型
    [Linux] 理解I/O多路复用
  • 原文地址:https://www.cnblogs.com/guo-eric/p/9040201.html
Copyright © 2011-2022 走看看