# 5.標籤篇:audio和video
- audio 和 video
```html
<style>
* {
margin:0;
padding:0;
}
.video_player{
position:relative;
width:1000px;
height:500px;
margin:0 auto;
}
video{
position:absolute;
width:1000px;
height:500px;
left:0;
top:0;
}
.menu{
position:absolute;
width:100%;
height:50px;
background:rgba(0,0,0,.5);
bottom:0;
display:none;
}
.play{
position:absolute;
width:60px;
height:30px;
border:1px solid white;
text-align:center;
line-height:30px;
border-radius:10px;
margin:auto 0 auto 20px;
top:0;
bottom:0;
cursor:pointer;
}
.time{
position:absolute;
width:100px;
height:30px;
text-align:center;
line-height:30px;
margin:auto 0 auto 20px;
top:0;
bottom:0;
cursor:pointer;
}
.progress_bar{
position:absolute;
width:100%;
height:2px;
background:gray;
left:0;
top:-2px;
}
.progress_bar div{
position:absolute;
width:0px;
height:2px;
background:orange;
left:0;
top:0;
}
.progress_bar i{
position:absolute;
width:6px;
height:6px;
background:white;
border-radius:3px;
left:120px;
top:-2px;
}
.quick{
position:absolute;
width:60px;
height:30px;
border:1px solid white;
text-align:center;
line-height:30px;
color:white;
border-radius:10px;
margin:auto 0 auto 20px;
top:0;
left:800px;
bottom:0;
cursor:pointer;
}
.quick_list{
position:absolute;
width:80px;
height:120px;
background:pink;
left:800px;
top:-120px;
color:#fff;
background-color:rgba(0,0,0,.5);
display:none;
}
.quick_list li{
position:relative;
width:100%;
height:30px;
text-align:center;
line-height:30px;
list-style:none;
cursor:pointer;
}
.quick_list li:hover{
color:green;
}
.vol_add{
position:absolute;
width:60px;
height:30px;
border:1px solid white;
text-align:center;
line-height:30px;
color:white;
border-radius:10px;
margin:auto 0 auto 20px;
top:0;
left:500px;
cursor:pointer;
}
.vol_ins{
position:absolute;
width:60px;
height:30px;
border:1px solid white;
text-align:center;
line-height:30px;
color:white;
border-radius:10px;
margin:auto 0 auto 20px;
top:0;
left:580px;
cursor:pointer;
}
.full_screen{
position:absolute;
width:60px;
height:30px;
border:1px solid white;
text-align:center;
line-height:30px;
color:white;
border-radius:10px;
margin:auto 0 auto 20px;
top:0;
left:880px;
cursor:pointer;
}
</style>
<div class="video_player">
<video src="view.mov"></video>
<div class="menu">
<div class="play">播放</div>
<div class="time">0:00/0:00</div>
<div class="progress_bar">
<div></div>
<i></i>
</div>
<div class="quick">倍速</div>
<div class="quick_list">
<ul>
<li>正常</li>
<li>1.25</li>
<li>1.5</li>
<li>2.0</li>
</ul>
</div>
<div class="vol_add">音量加</div>
<div class="vol_ins">音量減</div>
<div class="full_screen">全屏</div>
</div>
</div>
<script>
var videoPlayer = document.getElementByClassName("video_player")[0];
var menu = document.getElementByClassName("menu")[0];
var play = document.getElementByClassName("play")[0];
var video = document.getElementsByTagName("video")[0];
var time = document.getElementByClassName("time")[0];
var progressBar = document.getElementByClassName("progress_bar")[0];
var quick = document.getElementByClassName("quick")[0];
var quickList = document.getElementByClassName("quick_list")[0];
var volAdd = document.getElementByClassName("vol_add")[0];
var volIns = document.getElementByClassName("vol_ins")[0];
var fullScreen = document.getElementByClassName("full_screen")[0];
videoPlayer.onmouseenter = function(){
menu.style.display = "block";
};
videoPlayer.onmouseleave = function(){
menu.style.display = "none";
};
play.onclick = function(){//視頻播放與暫停
if(video.paused){//視頻處於暫停狀態
video.play();//視頻播放
play.innerHTML = "暫停";
}else{
video.pause();//視頻暫停
play.innerHTML = "播放";
}
};
setInterval(function(){
var total = video.duration;//視頻總時長
var nowTime = video.currentTime;//當前播放時間
time.innerHTML = parseInt(nowTime/60) + ":" + parseInt(nowTime%60) + "/" + parseInt(total/60) + ":" + parseInt(total%60);//設置播放時間
var progressBarWidth = nowTime / total * progressBar.clientWidth;
progressBar.getElementsByTagName("div")[0].style.width = width + "px";
progressBar.getElementsByTagName("i")[0].style.left = width + "px";
}, 1000);
progressBar.onmouseenter = function(){
progressBar.style.height = "14px";
progressBar.style.top = "-14px";
progressBar.getElementsByTagName("div")[0].style.height = "14px";
progressBar.getElementsByTagName("i")[0].style.height = "18px";
};
progressBar.onmouseleave = function(){
progressBar.style.height = "2px";
progressBar.style.top = "-2px";
progressBar.getElementsByTagName("div")[0].style.height = "2px";
progressBar.getElementsByTagName("i")[0].style.height = "6px";
};
progressBar.onclick = function(e){
var location = e.layerX;
var width = progressBar.clientWidth;
var targetTime = location / width * video.duration;
video.currentTime = targetTime;//只有在響應頭(Response Headers)裏面有Content-Range屬性,才能進行進度跳轉,不然不能進行跳轉
};
quick.onclick = function(){
quickList.style.display = "block";
}
quick.onmouseleave = function(){
quickList.style.display = "none";
}
var liList = quickList.getElementsByTagName("ul")[0].getElementsByTagName("li");
for(var i = 0; i < liList.length; i++){
list[i].index = i;
list[i].onclick = function(){
if(this.index == 0){//正常
video.playbackRate = 1;//設置速率
quick.innerHTML = "倍速";
}else if(this.index == 1){//1.25
video.playbackRate = 1.25;
quick.innerHTML = "x 1.25";
}else if(this.index == 2){//1.5
video.playbackRate = 1.5;
quick.innerHTML = "x 1.5";
}else if(this.index == 3){//2
video.playbackRate = 2;
quick.innerHTML = "x 2";
}
}
}
volAdd.onclick = function(){
video.volume = video.volume + 0.1 > 1 ? 1 : video.volume + 0.1;
}
volIns.onclick = function(){
video.volume = video.volume - 0.1 < 0 ? 0 : video.volume - 0.1;
}
fullScreen.onclick = function(){
var dom = document.documentElement;
dom.requestFullscreen();//全屏
videoPlayer.style.width = window.screen.width + "px";
videoPlayer.style.height = window.screen.height + "px";
video.style.style.width = window.screen.width + "px";
video.style.style.height = window.screen.height + "px";
}
videoPlayer.onmousemove = function(){
//利用函數防抖控制菜單隱藏,未實現
menu.style.display = "block";
};
</script>
```
以上是markdown格式的筆記