HTML5 Video DOM 入门体验

简介:

HTML5的一个新特性就是内置对多媒体的支持,<video> 元素很好用,也支持了不错的API接口,下面用了一个案例来说明怎么对<video> 元素的控制。

 
  1. <!DOCTYPE > 
  2. <html> 
  3. <head> 
  4.     <title></title> 
  5.  
  6.     <script src="js/jquery-1.7.1.min.js" type="text/javascript"></script> 
  7.  
  8.     <script type="text/javascript"> 
  9.         $(  
  10.         function() {  
  11.             $(":button").click(  
  12.             function() {  
  13.                 var h;  
  14.                 switch ($(":button").index($(this))) {  
  15.                     case 0:  
  16.                         if ($("video")[0].paused) {  
  17.                             $("video")[0].play();  
  18.                             $(this).val("暂停");  
  19.                         }  
  20.                         else {  
  21.                             $("video")[0].pause();  
  22.                             $(this).val("播放");  
  23.                         }  
  24.                         break;  
  25.                     case 1:  
  26.                         h = document.getElementsByTagName("video")[0].height == 0 ?  
  27.                             document.getElementsByTagName("video")[0].videoHeight - 10 :  
  28.                             document.getElementsByTagName("video")[0].height - 10; ;  
  29.                         document.getElementsByTagName("video")[0].height = h;  
  30.                         document.getElementsByTagName("video")[0].videoHeight = h;  
  31.                         break;  
  32.                     case 2:  
  33.                         h = document.getElementsByTagName("video")[0].height == 0 ?  
  34.                             document.getElementsByTagName("video")[0].videoHeight + 10 :  
  35.                             document.getElementsByTagName("video")[0].height + 10; ;  
  36.                         document.getElementsByTagName("video")[0].height = h;  
  37.                         document.getElementsByTagName("video")[0].videoHeight = h;  
  38.                         break;  
  39.                 }  
  40.             }  
  41.             );  
  42.         }  
  43.         );  
  44.  
  45.  
  46.         $(  
  47.         function() {  
  48.             $("#video1").on(  
  49.             "canplay",  
  50.             function(e) {  
  51.                 $(":button").removeAttr("disabled");  
  52.                 console.log(e);  
  53.             }  
  54.             );  
  55.             $("#video1").on(  
  56.             "canplaythrough",  
  57.             function(e) {  
  58.                 $("ol>li:eq(0)").html("全部加载完毕,你可以断网看电影了!");  
  59.                 console.log(e);  
  60.             }  
  61.             );  
  62.             $("#video1").bind(  
  63.             "playing waiting ended play pause",  
  64.             function(e) {  
  65.                 var vObj = document.getElementById("video1");  
  66.                 $("ol>li:eq(1)").html(vObj.duration + ":" + vObj.startTime + ":" + vObj.currentTime);  
  67.                 console.log(e);  
  68.             }  
  69.             );  
  70.             $("#video1").on(  
  71.             "stalled",  
  72.             function(e) {  
  73.                 $("ol>li:eq(2)").html("你的网络不给力啊,正在等数据呢");  
  74.                 console.log(e);  
  75.             }  
  76.             );  
  77.             $("#video1").on(  
  78.             "error",  
  79.             function(e) {  
  80.                 switch (e.target.error.code) {  
  81.                     case e.target.error.MEDIA_ERR_ABORTED:  
  82.                         $("ol>li:eq(3)").html("媒体资源获取异常");  
  83.                         break;  
  84.                     case e.target.error.MEDIA_ERR_NETWORK:  
  85.                         $("ol>li:eq(3)").html("网络错误");  
  86.                         break;  
  87.                     case e.target.error.MEDIA_ERR_DECODE:  
  88.                         $("ol>li:eq(3)").html("媒体解码错误");  
  89.                         break;  
  90.                     case e.target.error.MEDIA_ERR_SRC_NOT_SUPPORTED:  
  91.                         $("ol>li:eq(3)").html("视频格式被不支持");  
  92.                         break;  
  93.                     default:  
  94.                         $("ol>li:eq(3)").html("这个是神马错误啊");  
  95.                         break;  
  96.                 }  
  97.                 console.log(e);  
  98.             }  
  99.             );  
  100.             $("#video1").on(  
  101.             "suspend abort progress",  
  102.             function(e) {  
  103.                 var vObj = document.getElementById("video1");  
  104.                 $("ol>li:eq(1)").html(vObj.duration + ":" + vObj.startTime + ":" + vObj.currentTime);  
  105.                 console.log(e);  
  106.             }  
  107.             );  
  108.             $("#video1").on(  
  109.             "progress error abort",  
  110.             function(e) {  
  111.                 switch (e.target.readyState) {  
  112.                     case 0:  
  113.                         $("ol>li:eq(3)").html("当前播放位置无有效媒介资源");  
  114.                         break;  
  115.                     case 1:  
  116.                         $("ol>li:eq(3)").html("加载中,媒介资源确认存在,但当前位置没有能够加载到有效媒介数据进行播放");  
  117.                         break;  
  118.                     case 2:  
  119.                         $("ol>li:eq(3)").html("已获取到当前播放数据,但没有足够的数据进行播放");  
  120.                         break;  
  121.                     case 3:  
  122.                         $("ol>li:eq(3)").html("已获取到后续播放数据,可以进行播放");  
  123.                         break;  
  124.                     default:  
  125.                     case 4:  
  126.                         $("ol>li:eq(3)").html("可以进行播放,且浏览器确认媒体数据以某一种速度进行加载,可以保证有足够的后续数据进行播放,而不会使浏览器的播放进度赶上加载数据的末端");  
  127.                         break;  
  128.                 }  
  129.                 console.log(e);  
  130.             }  
  131.             );  
  132.         }  
  133.         );  
  134.          
  135.       
  136.     </script> 
  137.  
  138. </head> 
  139. <body> 
  140.     <video id="video1" autobuffer> 
  141.     <source src="video-test.mp4" type="video/mp4" /> 
  142.     对不起你的浏览器不支持HTML5的新特性,要不你下载一个  
  143.     <a href="http://info.msn.com.cn/ie9/">IE9</a>?   
  144.   </video> 
  145.     <input type="button" value="播放" disabled /> 
  146.     <input type="button" value="缩小" disabled /> 
  147.     <input type="button" value="放大" disabled /> 
  148.     <ol> 
  149.         <li></li> 
  150.         <li></li> 
  151.         <li></li> 
  152.         <li></li> 
  153.         <li></li> 
  154.     </ol> 
  155. </body> 
  156. </html> 

对 Video的控制重要的方法就是play、paused、stop。重要的事件有:

 

canplay 通知用户可以播放了,但不一定资源全部下载好

canplaythrough 资源都下载完毕了
 

error 出错时候

事件参数中有一个target对象,他有一个readyState值,可以得到不同的状态信息。具体的值,可以通过开发者工具获得,或看相关文档。



本文转自shyleoking 51CTO博客,原文链接:http://blog.51cto.com/shyleoking/806941

相关文章
|
3月前
|
JavaScript 前端开发 容器
用HTML DOM实现有条件地渲染网页元素(上)
用HTML DOM实现有条件地渲染网页元素(上)
|
26天前
|
移动开发 JavaScript 前端开发
HTML5 Video(视频)2
HTML5 `&lt;video&gt;` 标签及其相关属性和方法简介:支持 MP4、WebM 和 Ogg 视频格式。通过 JavaScript 控制播放、暂停、加载及设置属性如音量、尺寸等。示例展示了如何使用 `play()`、`pause()` 方法及 `paused`、`width` 属性创建基本的播放/暂停和调整尺寸控件。
|
3月前
|
存储 JavaScript 前端开发
用HTML DOM实现有条件地渲染网页元素(下)
用HTML DOM实现有条件地渲染网页元素(下)
|
26天前
|
Web App开发 移动开发 iOS开发
HTML5 Video(视频)1
HTML5引入了&lt;video&gt;元素,为网页视频播放提供标准方法。它支持播放、暂停和音量控制,以及视频尺寸设置。主要浏览器如IE9+、Firefox、Opera、Chrome和Safari均支持此元素。&lt;video&gt;元素可通过多个&lt;source&gt;子元素链接不同格式的视频文件,以确保兼容性。当前支持的视频格式包括MP4、WebM和Ogg。
|
2月前
|
JavaScript
HTML DOM 节点树
HTML DOM 节点是指在 HTML 文档对象模型中,文档中的所有内容都被视为节点。整个文档是一个文档节点,每个 HTML 元素是元素节点,元素内的文本是文本节点,属性是属性节点,注释是注释节点。DOM 将文档表示为节点树,节点之间有父子和同胞关系。
|
2月前
|
JavaScript
HTML DOM 节点
HTML DOM(文档对象模型)将HTML文档视为节点树,其中每个部分都是节点:文档本身是文档节点,HTML元素是元素节点,元素内的文本是文本节点,属性是属性节点,注释是注释节点。节点间存在父子及同胞关系,形成层次结构。
|
3月前
|
JavaScript 前端开发
JavaScript HTML DOM
JavaScript HTML DOM
43 2
JavaScript HTML DOM
|
3月前
|
移动开发 编解码 监控
HTML5 Video(视频)作为背景的优化方案
使用 HTML5 `&lt;video&gt;` 标签作为网页背景视频可以提升视觉效果,但需优化以确保性能和用户体验。主要方法包括:选择合适的视频格式(MP4、WebM、Ogg)和分辨率(720p 或更低),压缩文件大小,确保视频静音和循环播放,使用 CSS 设置全屏样式,根据设备和网络条件加载视频或静态图像,使用 `playsinline` 属性和延迟加载技术提高性能,确保无障碍性,并监控页面加载时间。合理应用背景视频可增强网站视觉效果而不影响用户体验。
|
3月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 节点列表
JavaScript HTML DOM 节点列表
22 5
|
3月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 集合(Collection)
JavaScript HTML DOM 集合(Collection)
38 4