vue項目中自定義video視頻控制條的實現(xiàn)代碼
最近公司項目中,添加了視頻模塊,但是產(chǎn)品覺得Video自帶的控制條有點LOW,于是自己設(shè)計了一個。于是開始了自定義Video控制的采坑之旅。。
首頁效果圖:

需求描述:
當(dāng)鼠標(biāo)放在圖片上的時候,自動播放視頻,并顯示預(yù)覽進(jìn)度條,當(dāng)鼠標(biāo)移開,顯示預(yù)覽圖片,再次hover圖片,繼續(xù)上次播放
視頻詳情頁的效果圖:

需求描述:
- 能自定義的暫停和播放
- 模仿進(jìn)度條可實現(xiàn)拖拽播放速度
- 顯示當(dāng)前時間
- 能選擇倍速
- 能控制聲音
- 能全屏播放
接下來一步步的實現(xiàn)
首先康康首頁的,上結(jié)構(gòu)代碼:
<div class="clickL video-box" @mouseover="play(item3.images_id)" @mouseout="pause(item3.images_id)"> <img v-lazy="item3.picture" width="268" alt="" v-show="id != item3.images_id"> <video class="video-hover" ref="videoAll" onMouseOver="this.play()" :src="item3.short_video" @timeupdate="commonVideoUpdata(index)" width="268px" height="176px" onMouseOut="this.pause()" muted loop="loop"> </video> </div> <div class="process-slider common-progress" v-show="id == item3.images_id"> <el-slider v-model="currentTimeProgress" :show-tooltip="false" input-size="small"></el-slider> </div>
這里思路是:
1,判斷用戶鼠標(biāo)事件,切換圖片和視頻。
2.video需要通過video來獲取他實例來進(jìn)行dom操作,video的鼠標(biāo)移入和滑出分類是控制視頻的播放和停止,play和pause是video的內(nèi)置方法。 更多方法見這里哦~
3.這里的進(jìn)度條使用的是element的滑動條組件,默認(rèn)max是100,顯示視頻的時候,這里用v-show判斷顯隱。
css部分代碼:
.video-box {
position: relative;
height: 176px;
&>img {
width: 100%;
height: 100%;
position: absolute;
left: 0;
top: 0;
z-index: 2;
}
&>video {
object-fit: fill; //拉伸填充盒子,保證和圖片一樣大
}
}
css部分主要是要注意讓video顯示的時候和圖片的寬高一致,不然就會出現(xiàn)圖片大,視頻小的情況,如圖:

邏輯部分:
data() {
return {
id:0, //保存當(dāng)前播放的視頻id
currentTimeVal:0 //進(jìn)度條
}
},
methods:{
//開始播放
play(val) {
this.id = val
},
// 停止播放,顯示圖片清零進(jìn)度條
pause(val) {
this.id = 0
this.currentTimeVal = 0
},
// 公共video獲取時間
commonVideoUpdata(id) {
let videoObj = this.$refs.videoAll
console.log(videoObj);
let currTime = videoObj[id].currentTime //當(dāng)前時間
let duration = videoObj[id].duration //總時間
let pre = currTime / duration
this.currentTimeProgress = pre * 100;
},
}
這里使用video 的timeupdate內(nèi)置方法獲取當(dāng)前播放時間,并獲取當(dāng)前的的dom元素,這里的videoObj打印出來是個數(shù)組:

我們通過當(dāng)前元素在數(shù)組中循環(huán)出來的索引來獲取對應(yīng)視頻的時間,最后一個簡單的計算進(jìn)度條的方法,(當(dāng)前時間 / 總時間)* 100 = 進(jìn)度條的值
注意坑點
:如果在數(shù)組中摻雜了其他的非視頻文件,這里使用ref的方式,就不能根據(jù)索引來獲取,就得定義唯一的ref,嘿嘿!
到此首頁功能結(jié)束了,接著實現(xiàn)詳情頁的自定義控制條。
html部分:
<div class="detali_box_img video-media">
<div class="video-example">
<video :src="item.video_file" width="100%" height="100%" loop="loop" preload="auto" @timeupdate="videoTimeUpdate" @click="controlVideo" ref="videoCon">
您的瀏覽器不支持 video 標(biāo)簽。
</video>
</div>
//視頻中的暫停按鈕
<div class="play-btn" @click="controlVideo" :style="[opcityVal]"></div>
// 控制條的播放和暫停按鈕
<div class="control-play">
<p class="control-play-btn" @click="controlVideo">
<span class="el-icon-video-play" v-show="!vcIsPlay"></span>
<span class="el-icon-video-pause" v-show="vcIsPlay"></span>
</p>
//播放進(jìn)度條
<div class="control-progress common-progress">
<div>
<el-slider v-model="vcProgress" :show-tooltip="false" :max="durationProgress" input-size="small" @change="getNewTime"></el-slider>
</div>
<!-- <p class="control-progress-item"></p> -->
</div>
//當(dāng)前播放時間
<div class="current-time">{{vcCurrentTime}}</div>
//視頻總時長
<div class="duration">{{item.duration_time}}</div>
//倍速控制
<div class="video-speed-box" @click="getPlayBackRate">
<el-dropdown placement="bottom" @command="handleCommand">
<!-- <span class="el-dropdown-link"> -->
<span class="video-speed-show">{{speedTime}}</span>
<!-- </span> -->
<el-dropdown-menu slot="dropdown">
<el-dropdown-item command="1">0.5x</el-dropdown-item>
<el-dropdown-item command="2">1x</el-dropdown-item>
<el-dropdown-item command="3">1.5x</el-dropdown-item>
<el-dropdown-item command="4">2x</el-dropdown-item>
<el-dropdown-item command="5">3x</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</div>
//音量控制
<div class="control-voice common-progress">
<span class="voice-icon"></span>
<div class="voice-slider">
<el-slider v-model="voiceProgress" input-size="small" @change="getNewVoice"></el-slider>
</div>
</div>
//全屏播放
<p class="fullscreen" title="全屏" @click="getFullSceen">
<span class="el-icon-full-screen"></span>
</p>
</div>
</div>
css部分忽略了。。。
直接看功能:首先data部分:
vcIsPlay: false, //是否播放
opcityVal: {
opacity: '1'
},
currentTimeVal: 0, // 當(dāng)前時間
vcCurrentTime: '00:00:00', //當(dāng)前時間格式化
vcProgress: 0, //進(jìn)度條的綁定時間
durationProgress: 0, //當(dāng)前視頻的總時長
speedTime: '1x', //倍速
voiceProgress: 0 //聲音
暫停和播放:
// 播放和暫停視頻
controlVideo() {
let videoObj = this.$refs.videoCon
this.durationProgress = videoObj[0].duration //總時間
if (this.vcIsPlay) {
videoObj[0].pause()
} else {
videoObj[0].play()
}
this.vcIsPlay = !this.vcIsPlay
this.opcityVal.opacity = this.opcityVal.opacity == '1' ? '0' : '1'
},
直接調(diào)用提供的兩個方法即可,然后使用vue的style綁定控制暫停按鈕的顯隱即可,這里的進(jìn)度條,我換了種玩法,同樣是element的滑動條組件,只不過max值我換成了總時長,單位秒,原因請耐心看下文,嘿嘿!

進(jìn)度條部分:
// 獲取時間
videoTimeUpdate() {
let videoObj = this.$refs.videoCon
let currTime = videoObj[0].currentTime //當(dāng)前時間
this.vcProgress = currTime //賦值給進(jìn)度條
this.vcCurrentTime = this.getFormatVideoTime(currTime)
console.log(this.vcCurrentTime) //"00:00:27"
},
//格式化時間
getFormatVideoTime(time) {
let curtime = time
let h = parseInt(curtime / 3600)
let m = parseInt((curtime % 3600) / 60)
let s = parseInt(curtime % 60)
h = h < 10 ? '0' + h : h
m = m < 10 ? '0' + m : m
s = s < 10 ? '0' + s : s
return h + ':' + m + ':' + s
},
這里難點是,我如何進(jìn)行拖動進(jìn)度條,來進(jìn)行控制呢?
別慌,看 代碼:
@change="getNewTime" //element 的滑動組件有個chang事件
getNewTime(val) {
let videoObj = this.$refs.videoCon
console.log(val)
videoObj[0].currentTime = val
},
通過change進(jìn)度條,然后重新賦值給當(dāng)前時間就搞定了,可以說是炒雞舒服了

倍速部分:
// 獲取當(dāng)前播放的速度
handleCommand(val) {
let videoObj = this.$refs.videoCon
switch (val) {
case '1':
videoObj[0].playbackRate = 0.5
this.speedTime = '0.5x'
break
case '2':
videoObj[0].playbackRate = 1
this.speedTime = '1x'
break
case '3':
videoObj[0].playbackRate = 1.5
this.speedTime = '1.5x'
break
case '4':
videoObj[0].playbackRate = 2
this.speedTime = '2x'
break
case '5':
videoObj[0].playbackRate = 3
this.speedTime = '3x'
break
default:
videoObj[0].playbackRate = 1
this.speedTime = '1x'
break
}
},
看圖:

這里使用的是element的下拉組件,同樣,Video的playbackRate可以直接賦值,控制播放速度
聲音部分:
// 設(shè)置聲音
getNewVoice(val) {
let videoObj = this.$refs.videoCon
let newVc = val / 100 //h5規(guī)定,volume的值必須再0-1之間,比如0.5就是50%的音量,但是進(jìn)度條的值為100,因此這里做個除法
videoObj[0].volume = newVc //賦值
},
我也是使用的滑組件,max值保持默認(rèn)的100,然后滑動改變的時候,把默認(rèn)值除100,比如當(dāng)前滑塊的新值是50,除100后得到的就是【0-1】范圍里的合法值,Video提供的volume值如果不在 0-1之間,就會報錯
最后是全屏部分:
// 全屏播放
getFullSceen() {
let videoObj = this.$refs.videoCon
videoObj[0].webkitRequestFullScreen()
},
但是我看到網(wǎng)上還有一種方法是模擬按下f11的全部,如果有興趣也可以了解下!
總結(jié)
因為之前沒有很仔細(xì)的搞過video,所以對它很多的內(nèi)置屬性和方法不了解,沒經(jīng)驗就害怕,很慌很慌,這就跟談戀愛似的,哈哈哈,再組長的支持和鼓勵下,我大膽的嘗試了,成功后,這次經(jīng)驗給了我很大信心,感覺以后寫其他沒做過的功能,都不會慌了,畢竟難的部分寫elementUi的大佬們都給寫好了,可以說是站在巨人的肩膀上,哈哈哈!膜拜大佬,以后還得多多努力了。
到此這篇關(guān)于vue項目中自定義video視頻控制條的實現(xiàn)代碼的文章就介紹到這了,更多相關(guān)vue 自定義video視頻控制條內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue video和vue-video-player實現(xiàn)視頻鋪滿教程
- vue-video-player視頻播放器使用配置詳解
- vue+node 實現(xiàn)視頻在線播放的實例代碼
- vue項目中播放rtmp視頻文件流的方法
- vue實現(xiàn)移動端input上傳視頻、音頻
- vue-video-player實現(xiàn)實時視頻播放方式(監(jiān)控設(shè)備-rtmp流)
- vue結(jié)合el-upload實現(xiàn)騰訊云視頻上傳功能
- vue中上傳視頻或圖片或圖片和文字一起到后端的解決方法
- vue視頻播放插件vue-video-player的具體使用方法
- vue vantUI實現(xiàn)文件(圖片、文檔、視頻、音頻)上傳(多文件)
- Vue登錄主頁動態(tài)背景短視頻制作
- vue通過video.js解決m3u8視頻播放格式的方法
- Vue結(jié)合Video.js播放m3u8視頻流的方法示例
- 如何在vue中使用video.js播放m3u8格式的視頻
相關(guān)文章
vue-router啟用history模式下的開發(fā)及非根目錄部署方法
這篇文章主要介紹了vue-router啟用history模式下的開發(fā)及非根目錄部署方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
在vue項目中 實現(xiàn)定義全局變量 全局函數(shù)操作
這篇文章主要介紹了在vue項目中 實現(xiàn)定義全局變量 全局函數(shù)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10
vue element 多圖片組合預(yù)覽的實現(xiàn)
本文主要介紹了vue element多圖片預(yù)覽實現(xiàn)的相關(guān)資料,最近的項目中有圖片預(yù)覽的場景,本文就來介紹一下如何使用,感興趣的可以了解一下2023-08-08
關(guān)于Element-UI Table 表格指定列添加點擊事件
這篇文章主要介紹了關(guān)于Element-UI Table 表格指定列添加點擊事件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
vue中axios利用blob實現(xiàn)文件瀏覽器下載方式
這篇文章主要介紹了vue中axios利用blob實現(xiàn)文件瀏覽器下載方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
在Vue中使用動態(tài)import()語法動態(tài)加載組件
在Vue中,你可以使用動態(tài)import()語法來動態(tài)加載組件,動態(tài)導(dǎo)入允許你在需要時異步加載組件,這樣可以提高應(yīng)用程序的初始加載性能,本文給大家介紹在Vue中使用動態(tài)import()語法動態(tài)加載組件,感興趣的朋友一起看看吧2023-11-11

