使用javascript实现监控视频播放并打印日志


Posted in Javascript onJanuary 05, 2015

最近在做一个项目,要求监控视频的播放事件并能够打印LOG日志,经过一番思索,使用javascript实现了此功能,代码如下:

HTML:

<!DOCTYPE html>

<html>

<head>

<meta http-equiv="content-type" content="text/html; charset=UTF-8">

<title>Multi Source</title>

</head>

<body>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

<video src="http://www.w3school.com.cn/i/movie.mp4" controls autoplay></video>

</body>

</html>

JS:

<script type="text/javascript">

window.addEventListener("load",getVideoEvent);

function getVideoEvent(){

var videoes=document.getElementsByTagName("video");

for (var i = 0; i < videoes.length; i++) {

showEventLog("video"+(i+1),videoes[i]);

}

}

function showEventLog(videoNum,Media){

eventTester = function(e){

Media.addEventListener(e,function(){

console.log(videoNum+":"+e);

});

}

eventTester("loadstart");    //客户端开始请求数据

eventTester("progress");    //客户端正在请求数据

eventTester("suspend");    //延迟下载

eventTester("abort");    //客户端主动终止下载(不是因为错误引起),

eventTester("error");    //请求数据时遇到错误

eventTester("stalled");    //网速失速

eventTester("play");    //play()和autoplay开始播放时触发

eventTester("pause");    //pause()触发

eventTester("loadedmetadata");    //成功获取资源长度

eventTester("loadeddata");    //

eventTester("waiting");    //等待数据,并非错误

eventTester("playing");    //开始回放

eventTester("canplay");    //可以播放,但中途可能因为加载而暂停

eventTester("canplaythrough"); //可以播放,歌曲全部加载完毕

eventTester("seeking");    //寻找中

eventTester("seeked");    //寻找完毕

eventTester("timeupdate");    //播放时间改变

eventTester("ended");    //播放结束

eventTester("ratechange");    //播放速率改变

eventTester("durationchange");    //资源长度改变

eventTester("volumechange");    //音量改变

}

</script>

小伙伴们主要看下本文的思路即可,希望对大家能有所帮助

Javascript 相关文章推荐
js+css实现tab菜单切换效果的方法
Jan 20 Javascript
jQuery实现字符串按指定长度加入特定内容的方法
Mar 11 Javascript
jquery比较简洁的软键盘特效实现方法
Mar 19 Javascript
使用jquery+CSS3实现仿windows10开始菜单的下拉导航菜单特效
Sep 24 Javascript
js格式化时间的简单实例
Nov 27 Javascript
js防刷新的倒计时代码 js倒计时代码
Sep 06 Javascript
Vue.js在数组中插入重复数据的实现代码
Nov 17 Javascript
bootstrap fileinput插件实现预览上传照片功能
Jan 23 Javascript
微信小程序实现日历效果
Dec 28 Javascript
vue 中 beforeRouteEnter 死循环的问题
Apr 23 Javascript
vue实现短信验证码输入框
Apr 17 Javascript
vue打包时去掉所有的console.log
Apr 10 Vue.js
jQuery圆形统计图开发实例
Jan 04 #Javascript
jQuery中:selected选择器用法实例
Jan 04 #Javascript
jQuery中:checked选择器用法实例
Jan 04 #Javascript
jQuery中:disabled选择器用法实例
Jan 04 #Javascript
AngularJS中取消对HTML片段转义的方法例子
Jan 04 #Javascript
jQuery中:enabled选择器用法实例
Jan 04 #Javascript
jQuery中:file选择器用法实例
Jan 04 #Javascript
You might like
windows环境下php配置memcache的具体操作步骤
2013/06/09 PHP
Linux下安装oracle客户端并配置php5.3
2014/10/12 PHP
浅析php单例模式
2014/11/25 PHP
PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例
2015/05/12 PHP
PHP实现的购物车类实例
2015/06/17 PHP
PHP MSSQL 分页实例
2016/04/13 PHP
PhpStorm terminal无法输入命令的解决方法
2016/10/09 PHP
PHP _construct()函数讲解
2019/02/03 PHP
jQuery contains过滤器实现精确匹配使用方法
2013/04/12 Javascript
js加载之使用DOM方法动态加载Javascript文件
2013/11/08 Javascript
jquery对table中各数据的增加、保存、删除操作示例
2014/05/14 Javascript
JavaScript中Function详解
2015/02/27 Javascript
深入理解JavaScript系列(50):Function模式(下篇)
2015/03/04 Javascript
JS模仿手机端九宫格登录功能实现代码
2016/04/28 Javascript
网页中的图片查看器viewjs使用方法
2017/07/11 Javascript
React Native中TabBarIOS的简单使用方法示例
2017/10/13 Javascript
JS开发中基本数据类型具体有哪几种
2017/10/19 Javascript
JavaScript设计模式之构造函数模式实例教程
2018/07/02 Javascript
详解VUE中常用的几种import(模块、文件)引入方式
2018/07/03 Javascript
layer弹出层 iframe层去掉滚动条的实例代码
2018/08/17 Javascript
Vue项目配置跨域访问和代理proxy设置方式
2020/09/08 Javascript
vue实现动态表格提交参数动态生成控件的操作
2020/11/09 Javascript
[06:10]6.81新信使新套装!给你一个炫酷的DOTA2
2014/05/06 DOTA
Python中请使用isinstance()判断变量类型
2014/08/25 Python
Python使用random和tertools模块解一些经典概率问题
2015/01/28 Python
在Python的Django框架中显示对象子集的方法
2015/07/21 Python
Python编程求解二叉树中和为某一值的路径代码示例
2018/01/04 Python
更新升级python和pip版本后不生效的问题解决
2020/04/17 Python
使用Django的JsonResponse返回数据的实现
2021/01/15 Python
美国汽车交易网站:Edmunds
2016/08/17 全球购物
美国马匹用品和骑马配件购物网站:Horse.com
2018/01/08 全球购物
Michael Kors英国官网:美国奢侈品品牌
2019/11/13 全球购物
《记承天寺夜游》教学反思
2014/02/16 职场文书
银行授权委托书格式
2014/10/10 职场文书
vue实现滑动解锁功能
2022/03/03 Vue.js
sqlserver连接错误之SQL评估期已过的问题解决
2022/03/23 SQL Server