vue2.0實現(xiàn)音樂/視頻播放進(jìn)度條組件
基于vue2.0實現(xiàn)音樂/視頻播放進(jìn)度條組件的方法及代碼解釋,具體內(nèi)容如下
需求分析:
①:進(jìn)度條隨著歌曲的播放延長,歌曲播放完時長度等于黑色總進(jìn)度條長度;時間實時更新。
②:當(dāng)滑動按鈕時,實時更新播放時間,橙色進(jìn)度條長度也會隨著按鈕的滑動而改變,當(dāng)滑動結(jié)束時,橙色區(qū)域停留在滑動結(jié)束的位置,歌曲從當(dāng)前進(jìn)度開始播放。
③:點擊進(jìn)度條,橙色進(jìn)度條長度變?yōu)辄c擊處至起點的長度,并從當(dāng)前點開始播放歌曲。
大概思路:
①:左邊的時間可以通過audio播放時派發(fā)的timeupdate事件獲取,右邊的時間為接口獲取的當(dāng)前歌曲的總時間。
②:進(jìn)度條子組件的長度通過父組件傳入一個percent值計算,percent值為播放進(jìn)度與總進(jìn)度的比值。
③:進(jìn)度條的滑動及點擊結(jié)束后,需要向父組件傳遞一個percent值,使用this.$emit()像父組件派發(fā)事件,父組件中設(shè)置事件響應(yīng)函數(shù),接收percent參數(shù)值,用于改變audio中當(dāng)前播放的音樂進(jìn)度。
詳細(xì)實現(xiàn),關(guān)鍵代碼已經(jīng)注釋:
先上組件源碼:
<template> <div class="progress-bar" ref="progressBar" @click="progressClick"> <div class="bar-inner"> <div class="progress" ref="progress"></div> <div class="progress-btn-wrapper"ref="progressBtn" @touchstart.prevent = "progressTouchStart" @touchmove.prevent = "progressTouchMove" @touchend = "progressTouchEnd" > <div class="progress-btn"></div> </div> </div> </div> </template> <script type="text/ecmascript-6"> // 進(jìn)度條按鈕寬度,由于style中沒有設(shè)置width,因此只能用clientWidth獲取 export default { data() { return { btnWidth: { type: Number, default: 0 }, touchInfo: { initiated: false } } }, props: { percent: { type: Number, default: 0 } }, mounted() { this.btnWidth = document.getElementsByClassName('progress-btn')[0].clientWidth }, methods: { // 點擊按鈕 progressTouchStart(e) { // 記錄touch事件已經(jīng)初始化 this.touchInfo.initiated = true // 點擊位置 this.touchInfo.startX = e.touches[0].pageX // 點擊時進(jìn)度條長度 this.touchInfo.left = this.$refs.progress.clientWidth }, // 開始移動 progressTouchMove(e) { if (!this.touchInfo.initiated) { return } // 計算移動距離 const moveX = e.touches[0].pageX - this.touchInfo.startX // 設(shè)置偏移值 const offsetWidth = Math.min(Math.max(0, this.touchInfo.left + moveX), this.$refs.progressBar.clientWidth - this.btnWidth) this._setOffset(offsetWidth) }, // 移動結(jié)束 progressTouchEnd(e) { this.touchInfo.initiated = false // 向父組件派發(fā)事件,傳遞當(dāng)前百分比值 this._triggerPercent() }, // 進(jìn)度條點擊事件 progressClick(e) { console.log('clikc') // 設(shè)置進(jìn)度條及按鈕偏移 this._setOffset(e.offsetX) // 通知父組件播放進(jìn)度變化 this._triggerPercent() }, _triggerPercent() { const barWidth = this.$refs.progressBar.clientWidth - this.btnWidth const percent = Math.min(1, this.$refs.progress.clientWidth / barWidth) this.$emit('percentChange', percent) }, // 設(shè)置偏移 _setOffset(offsetWidth) { // 設(shè)置進(jìn)度長度隨著百分比變化 this.$refs.progress.style.width = `${offsetWidth}px` // 設(shè)置按鈕隨著百分比偏移 this.$refs.progressBtn.style.transform = `translate3d(${offsetWidth}px, 0, 0)` } }, watch: { // 監(jiān)聽歌曲播放百分比變化 percent(newPercent, oldPercent) { if (newPercent > 0 && !this.touchInfo.initiated) { // 進(jìn)度條總長度 const barWidth = this.$refs.progressBar.clientWidth - this.btnWidth const offsetWidth = barWidth * newPercent // 設(shè)置進(jìn)度條及按鈕偏移 this._setOffset(offsetWidth) } } } } </script> <style lang="stylus" rel="stylesheet/stylus"> @import "~common/stylus/variable.styl" .progress-bar height 0.5rem .bar-inner position relative top 0.2rem height 0.08rem background rgba(0, 0, 0, 0.3) .progress position absolute height 100% background $color-theme .progress-btn-wrapper position absolute left -0.25rem top -0.25rem width 0.5rem height 0.5rem .progress-btn position relative top 0.12rem left 0.12rem box-sizing border-box width 0.32rem height 0.32rem border 0.06rem solid $color-text border-radius 50% background $color-theme </style>
此為progerss-bar.vue組件源碼,組件所需要父組件傳入的值只有一個“percent”,為父組件中audio當(dāng)前播放時間與總時間的比值,用于計算此組件中橙色進(jìn)度條的長度。
組件的使用:
首先導(dǎo)入并注冊組件(在此不做解釋),隨后使用此組件,dom:
<div class="progress-wrapper"> <span class="time time-l">{{formatTime(currentTime)}}</span> <div class="progress-bar-wrapper"> <progress-bar :percent="percent" @percentChange="setProgress"></progress-bar> </div> <span class="time time-r">{{formatTime(currentSong.duration)}}</span> </div>
解釋:兩個span為左右兩個時間值,progress-bar為調(diào)用的組件,需要傳入percent值,用于子組件設(shè)置進(jìn)度條長度
percent值來自于audio的currenTime與歌曲總長度的比值:
// 計算百分比 percent() { return Math.min(1, this.currentTime / this.currentSong.duration) }
@percentChange為子組件中派發(fā)過來的事件,詳細(xì)請看子組件中源碼及注釋“_triggerPercent()”部分,此事件調(diào)用的方法用于接收子組件傳過來的拖動按鈕、點擊進(jìn)度條改變歌曲播放進(jìn)度后的播放百分比,用于改變父組件中audio標(biāo)簽的currentTime,進(jìn)而將歌曲播放進(jìn)度設(shè)置為當(dāng)前時間。
以下為父組件中,接收到子組件派發(fā)過來的事件后調(diào)用的函數(shù)。
// 設(shè)置進(jìn)度 setProgress(percent) { // 根據(jù)子組件傳過來的百分比設(shè)置播放進(jìn)度 this.$refs.audio.currentTime = this.currentSong.duration * percent // 拖動后設(shè)置歌曲播放 if (!this.playing) { this.togglePlaying() } },
樣式(本人使用stylus):
.progress-wrapper display flex .time font-size 0.24rem &.time-l position absolute bottom 1.62rem left 1rem &.time-r position absolute bottom 1.62rem right 1rem .progress-bar-wrapper position absolute bottom 1.5rem left 1.7rem width 4.2rem
至此,進(jìn)度條組件的實現(xiàn)及使用方法均介紹完畢。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue2+springsecurity權(quán)限系統(tǒng)的實現(xiàn)
本文主要介紹了vue2+springsecurity權(quán)限系統(tǒng)的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Vue3實現(xiàn)SSE(Server-Sent?Events)連接
SSE?是一種允許服務(wù)器向瀏覽器推送事件的技術(shù),這篇文章主要為大家詳細(xì)介紹了如何通過vue3實現(xiàn)SSE(Server-Sent?Events)連接,有需要的小伙伴可以了解下2024-10-10Vue3學(xué)習(xí)之語法糖、箭頭函數(shù)、函數(shù)聲明詳解
在Vue3中箭頭函數(shù)被廣泛支持,尤其是在組合式API的上下文中,這篇文章主要給大家介紹了關(guān)于Vue3學(xué)習(xí)之語法糖、箭頭函數(shù)、函數(shù)聲明的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08vue使用axios實現(xiàn)excel文件下載的功能
這篇文章主要介紹了vue中使用axios實現(xiàn)excel文件下載的功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07