video记录视频播放时长

编程入门 行业动态 更新时间:2024-10-14 14:22:30

video记录视频播放<a href=https://www.elefans.com/category/jswz/34/1766056.html style=时长"/>

video记录视频播放时长

一、背景:需要记录视频播放时长

html使用video控件,需每隔一段时间记录前端视频的播放时长。

二、应用:选择timeupdate的监听事件

由于该事件是每隔250毫秒运行一次,太频繁了,而且回传结果是毫秒,需要改写为 分/秒  的格式。

// 14、timeupdate:目前的播放位置已更改时,播放时间更新video.addEventListener('timeupdate', function(e) {console.log('timeupdate')console.log(e)})

三、改写:转为计量单位

video.addEventListener('timeupdate', (e)=> {//每250毫秒运行一次。转为秒var duration = e.timeStamp/1000; //每5秒更新数据库;if(Math.round(duration)%5==0){		// TODOint h = duration::int / 3600;int m = (duration::int % 3600) / 60;int s = (duration::int % 3600) % 60;}
})			

四、video 事件监听

<video src="test.mp4" controls width="400" height="300" id="video"></video><script>var video = document.getElementById('video')// 或用var video = document.querySelector('video')// 1、loadstart:视频查找。当浏览器开始寻找指定的音频/视频时触发,也就是当加载过程开始时video.addEventListener('loadstart', function(e) {console.log('提示视频的元数据已加载')console.log(e)console.log(video.duration)            // NaN})// 2、durationchange:时长变化。当指定的音频/视频的时长数据发生变化时触发,加载后,时长由 NaN 变为音频/视频的实际时长video.addEventListener('durationchange', function(e) {console.log('提示视频的时长已改变')console.log(e)console.log(video.duration)           // 528.981333   视频的实际时长(单位:秒)})// 3、loadedmetadata :元数据加载。当指定的音频/视频的元数据已加载时触发,元数据包括:时长、尺寸(仅视频)以及文本轨道video.addEventListener('loadedmetadata', function(e) {console.log('提示视频的元数据已加载')console.log(e)})// 4、loadeddata:视频下载监听。当当前帧的数据已加载,但没有足够的数据来播放指定音频/视频的下一帧时触发video.addEventListener('loadeddata', function(e) {console.log('提示当前帧的数据是可用的')console.log(e)})// 5、progress:浏览器下载监听。当浏览器正在下载指定的音频/视频时触发video.addEventListener('progress', function(e) {console.log('提示视频正在下载中')console.log(e)})// 6、canplay:可播放监听。当浏览器能够开始播放指定的音频/视频时触发video.addEventListener('canplay', function(e) {console.log('提示该视频已准备好开始播放')console.log(e)})// 7、canplaythrough:可流畅播放。当浏览器预计能够在不停下来进行缓冲的情况下持续播放指定的音频/视频时触发video.addEventListener('canplaythrough', function(e) {console.log('提示视频能够不停顿地一直播放')console.log(e)})// 8、play:播放监听video.addEventListener('play', function(e) {console.log('提示该视频正在播放中')console.log(e)})// 9、pause:暂停监听video.addEventListener('pause', function(e) {console.log('暂停播放')console.log(e)})// 10、seeking:查找开始。当用户开始移动/跳跃到音频/视频中新的位置时触发video.addEventListener('seeking', function(e) {console.log('开始移动进度条')console.log(e)})// 11、seeked:查找结束。当用户已经移动/跳跃到视频中新的位置时触发video.addEventListener('seeked', function(e) {console.log('进度条已经移动到了新的位置')console.log(e)})// 12、waiting:视频加载等待。当视频由于需要缓冲下一帧而停止,等待时触发video.addEventListener('waiting', function(e) {console.log('视频加载等待')console.log(e)})// 13、playing:当视频在已因缓冲而暂停或停止后已就绪时触发video.addEventListener('playing', function(e) {console.log('playing')console.log(e)})// 14、timeupdate:目前的播放位置已更改时,播放时间更新video.addEventListener('timeupdate', function(e) {console.log('timeupdate')console.log(e)})// 15、ended:播放结束video.addEventListener('ended', function(e) {console.log('视频播放完了')console.log(e)})// 16、error:播放错误video.addEventListener('error', function(e) {console.log('视频出错了')console.log(e)})// 17、volumechange:当音量更改时video.addEventListener('volumechange', function(e) {console.log('volumechange')console.log(e)})// 18、stalled:当浏览器尝试获取媒体数据,但数据不可用时video.addEventListener('stalled', function(e) {console.log('stalled')console.log(e)})// 19、ratechange:当视频的播放速度已更改时video.addEventListener('ratechange', function(e) {console.log('ratechange')console.log(e)})</script>

相关链接:video 标签 各种属性及所有事件监听大全_video标签事件监听-CSDN博客

更多推荐

video记录视频播放时长

本文发布于:2023-12-06 07:33:06,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1666883.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:时长   视频播放   video

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!