比如:向上键对应的keyCode为38,向下键对应的keyCode为40,向左键对应的keyCode为37,向右键对应的keyCode为39,空格键对应的keyCode为32,
其他的keyCode可以通过 console.log("keyCode:" + event.keyCode); 打印获取。
获取视频元素:var videoElement = document.getElementById("videoPlay");
获取设置音量大小:videoElement.volume
获取设置当前播放的位置:videoElement.currentTime
播放视频:videoElement.play()
暂停视频:videoElement.pause()
1 //reurn false 禁止函数内部执行其他的事件或者方法
2 var vol = 0.1; //1代表100%音量,每次增减0.1
3 var time = 10; //单位秒,每次增减10秒
4 var videoElement = document.getElementById("videoPlay");
5 console.log(videoElement.paused);
6
7 document.onkeyup = function (event) {//键盘事件
8
9 console.log("keyCode:" + event.keyCode);
10 var e = event || window.event || arguments.callee.caller.arguments[0];
11
12 //鼠标上下键控制视频音量
13 if (e && e.keyCode === 38) {
14
15 // 按 向上键
16 videoElement.volume !== 1 ? videoElement.volume += vol : 1;
17 return false;
18
19 } else if (e && e.keyCode === 40) {
20
21 // 按 向下键
22 videoElement.volume !== 0 ? videoElement.volume -= vol : 1;
23 return false;
24
25 } else if (e && e.keyCode === 37) {
26
27 // 按 向左键
28 videoElement.currentTime !== 0 ? videoElement.currentTime -= time : 1;
29 return false;
30
31 } else if (e && e.keyCode === 39) {
32
33 // 按 向右键
34 videoElement.volume !== videoElement.duration ? videoElement.currentTime += time : 1;
35 return false;
36
37 } else if (e && e.keyCode === 32) {
38
39 // 按空格键 判断当前是否暂停
40 videoElement.paused === true ? videoElement.play() : videoElement.pause();
41 return false;
42 }
43
44 };
转自:https://www.cnblogs.com/TF12138/p/4448108.html
html 代码
<video id="media" src="http://www.sundxs.com/test.mp4" controls width="400px" heigt="400px"></video>
//audio和video都可以通过JS获取对象,JS通过id获取video和audio的对象
Media = document.getElementById("media");
HTMLVideoElement和HTMLAudioElement 均继承自HTMLMediaElement
- Media.currentSrc; //返回当前资源的URL - Media.src = value; //返回或设置当前资源的URL - Media.canPlayType(type); //是否能播放某种格式的资源 - Media.networkState; //0.此元素未初始化 1.正常但没有使用网络 2.正在下载数据 3.没有找到资源 - Media.load(); //重新加载src指定的资源 - Media.buffered; //返回已缓冲区域,TimeRanges - Media.preload; //none:不预载 metadata:预载资源信息 auto:
- Media.readyState;//1:HAVE_NOTHING 2:HAVE_METADATA 3.HAVE_CURRENT_DATA 4.HAVE_FUTURE_DATA 5.HAVE_ENOUGH_DATA - Media.seeking; //是否正在seeking
var eventTester = function(e){
Media.addEventListener(e,function(){
console.log((new Date()).getTime(),e)
},false);
}