本文的目录:

1.获取影片总时长
2.播放、暂停
3.获取影片已播放时间和设置播放点
4.音量的获取和设置

第一、获取影片总时长

对播放器(video)操作,首先要得到的是影片的一些信息,其中一个就是总时长,除了内容以为,总时长也是第一时间要显示的。在对video进行操作的的前先给video标签添加一个ID,这样方便我们获取video元素

代码如下:
 
<video id="myVideo" controls preload="auto" width=300 height="165" 
poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg" 
src="http://www.w3cschool.cc/try/demo_source/mov_bbb.mp4"></video>

设置一个ID后,那么就可以开始操作了,要获取总时长,要用到video的一个事件-loadedmetadata,这个事件的触发表示元数据(媒体的一些基本信息)已经加载完成,用addEventListener监听事件

代码如下:
var myVideo = document.getElementById('myVideo');//获取video元素
myVideo.addEventListener("loadedmetadata", function(){
  //要执行的代码
});
好了,已经监听了,那么接下来要做的就是获取总时长,其实就是一个属性-duration
var myVideo = document.getElementById('myVideo'), //获取video元素
  tol = 0;
myVideo.addEventListener("loadedmetadata", function(){
  tol = myVideo.duration;//获取总时长
});

需要注意的是获取到的在总时长的单位为秒,显示的时候根据需要去转换。

第二、播放、暂停

对播放器来说最基本的一个功能就是播放和暂停了,而在获取总时长后,接着的操作也就是播放和暂停。这个时候用到了video的两个方法就是play和pause

代码如下:
var myVideo = document.getElementById('myVideo'),//获取video元素
  tol = 0;
myVideo.addEventListener("loadedmetadata", function(){
  tol = myVideo.duration;//获取总时长
});
//播放
function play(){ 
  myVideo.play();
}
//暂停
function pause(){ 
  myVideo.pause();
}

需要注意的是,当播放结束后再运行play方法将会从头播放。

  第三、获取影片的播放时间和设置播放点

播放器能播放和暂停后,那么接下来需要看到的就是影片播放了多久,播放到哪个时间点了。这个操作跟获取总时长很相似,都是需要监听一个事件和获取一个属性的值,那么用到的是video的timeupdate事件和currentTime属性

代码如下:
//播放时间点更新时
myVideo.addEventListener("timeupdate", function(){
  var currentTime = myVideo.currentTime;//获取当前播放时间
  console.log(currentTime);//在调试器中打印
});

运行后会在控制台看到很多数据...

我们经常会接到一个要求,那就是上次看到了10分钟了,这次看要从第十分钟开始看,那么这个时候就需要设置播放点了,设置播放点用得还是currentTime属性,currentTime属性是可读写的,要注意的是设置值的单位是秒,如果播放点不是秒为单位那就要进行转换

代码如下:
//设置播放点
function playBySeconds(num){ 
  myVideo.currentTime = num;
}

    第四、音量的获取和设置

播放器播放的过程中能暂停、播放,知道现在播放到哪里了和可以从某个时间点开始播放,那么接下来操作的就是音量了。这一点跟第三相似,获取音量可以直接用volume属性就可以了,但是在这里还要介绍的是音量改变的触发事件,方面以后需要自定义UI使用,那就是volumechange事件

代码如下:
//音量改变时
myVideo.addEventListener("volumechange", function(){
  var volume = myVideo.volume;//获取当前音量
  console.log(volume);//在调试器中打印
});

当你通过控制条来改变音量时,你会看到调试里面有很多数据。要注意的是音量的范围值为0~1,一般在UI中都是用百分比,所以需要的时候要进行转换。

音量是可以通过改变属性来设置的,跟播放的时间点是相似的,只不过音量设置的是volume属性

代码如下:
//设置音量
function setVol(num){ 
  myVideo.volume = num;
}

下面是完整的代码:

<!DOCTYPE html>
<html>
<head>
<title>Video-获取时长</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
</head>
<body>
<video id="myVideo" controls preload="auto" width= height=""
poster="http://img0.ph.126.net/I10JqUUJDmlEtE_XYl4hOg==/6608842237655242020.jpg"
src="http://www.w3cschool.cc/try/demo_source/mov_bbb.mp4"></video>
<script>
var myVideo = document.getElementById('myVideo'),//获取video元素
tol = ; //总时长
myVideo.addEventListener("loadedmetadata", function(){
tol = myVideo.duration;//获取总时长
alert('影片时长:'+ tol);
});
//播放
function play(){
myVideo.play();
}
//暂停
function pause(){
myVideo.pause();
}
//播放时间点更新时
myVideo.addEventListener("timeupdate", function(){
var currentTime = myVideo.currentTime;//获取当前播放时间
console.log(currentTime);//在调试器中打印
});
//设置播放点
function playBySeconds(num){
myVideo.currentTime = num;
}
//音量改变时
// myVideo.addEventListener("volumechange", function(){
// var volume = myVideo.volume;//获取当前音量
// console.log(volume);//在调试器中打印
// });
//设置音量
function setVol(num){
myVideo.volume = num;
}
</script>
</body>
</html>

总结:通过这四个步骤来了解html5标签video(播放器)的基本操作,而这些操作主要是通过JS来监听video的事件和对video属性的读写来完成的,熟悉这四点即可灵活的在使用播放器,再根据应用场景来调整即可

最新文章

  1. 使用 Redis 实现排行榜功能
  2. 对字符串进行简单的字符数字统计 探索java中的List功能
  3. HDU 2089 不要62
  4. [C#] 走进异步编程的世界 - 开始接触 async/await(转)
  5. 事件委托和this
  6. WCF HTTPS配置
  7. 对PostgreSQL xmin的深入学习
  8. POJ 2395 Out of Hay(最小生成树中的最大长度)
  9. poj1504--求两个数的反转数的和的反转数
  10. excel中匹配数据
  11. Android开发经验之—intent传递大数据
  12. Linux:用at和crontab调度作业
  13. CG之refract函数简单实现
  14. bootstrap建立响应式网站——tab选项卡
  15. 学习生命周期activity
  16. angular指令的4种设计模式
  17. android eclipse写layout文件失效问题解决
  18. 微信小程序 TLS 版本必须大于等于1.2问题解决
  19. 019_UT、IT、ST、UAT
  20. linux 下zip的用法实例

热门文章

  1. Qt create 如何构建 ActiveX 控件?
  2. python中__name__=='__main__'的作用
  3. C# 之三类文件的读写( .XML,.INI 和 .TXT 文件)
  4. csrf
  5. java编程思想第四版第五章习题
  6. Visual Studio Code搭建python开发环境
  7. 【mongodb系统学习之十】mongodb查询(三)
  8. freemarker.core.ParseException:Unexpected end of file reached
  9. FtpHelper ftp操作类库
  10. CentOS持久化二进制日志(systemd日志)