真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

這篇文章主要為大家展示了如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條,內(nèi)容簡(jiǎn)而易懂,希望大家可以學(xué)習(xí)一下,學(xué)習(xí)完之后肯定會(huì)有收獲的,下面讓小編帶大家一起來(lái)看看吧。

目前創(chuàng)新互聯(lián)公司已為近1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、南城網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

最近公司項(xiàng)目中,添加了視頻模塊,但是產(chǎn)品覺(jué)得Video自帶的控制條有點(diǎn)LOW,于是自己設(shè)計(jì)了一個(gè)。于是開(kāi)始了自定義Video控制的采坑之旅。。

首頁(yè)效果圖:

 如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

需求描述:

當(dāng)鼠標(biāo)放在圖片上的時(shí)候,自動(dòng)播放視頻,并顯示預(yù)覽進(jìn)度條,當(dāng)鼠標(biāo)移開(kāi),顯示預(yù)覽圖片,再次hover圖片,繼續(xù)上次播放

視頻詳情頁(yè)的效果圖:

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

需求描述:

  • 能自定義的暫停和播放
  • 模仿進(jìn)度條可實(shí)現(xiàn)拖拽播放速度
  • 顯示當(dāng)前時(shí)間
  • 能選擇倍速
  • 能控制聲音
  • 能全屏播放

接下來(lái)一步步的實(shí)現(xiàn)

首先康康首頁(yè)的,上結(jié)構(gòu)代碼:

這里思路是:

1,判斷用戶鼠標(biāo)事件,切換圖片和視頻。

2.video需要通過(guò)video來(lái)獲取他實(shí)例來(lái)進(jìn)行dom操作,video的鼠標(biāo)移入和滑出分類是控制視頻的播放和停止,play和pause是video的內(nèi)置方法。 更多方法見(jiàn)這里哦~

3.這里的進(jìn)度條使用的是element的滑動(dòng)條組件,默認(rèn)max是100,顯示視頻的時(shí)候,這里用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顯示的時(shí)候和圖片的寬高一致,不然就會(huì)出現(xiàn)圖片大,視頻小的情況,如圖:

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

邏輯部分:

data() {
 return {
 id:0, //保存當(dāng)前播放的視頻id
 currentTimeVal:0 //進(jìn)度條
 }
},
methods:{
 //開(kāi)始播放
 play(val) {
 this.id = val
 },
 // 停止播放,顯示圖片清零進(jìn)度條
 pause(val) {
 this.id = 0
 this.currentTimeVal = 0
 },
 // 公共video獲取時(shí)間
 commonVideoUpdata(id) {
  let videoObj = this.$refs.videoAll
  console.log(videoObj);
  let currTime = videoObj[id].currentTime //當(dāng)前時(shí)間
  let duration = videoObj[id].duration //總時(shí)間
  let pre = currTime / duration
  this.currentTimeProgress = pre * 100;
 },
}

這里使用video 的timeupdate內(nèi)置方法獲取當(dāng)前播放時(shí)間,并獲取當(dāng)前的的dom元素,這里的videoObj打印出來(lái)是個(gè)數(shù)組:

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

我們通過(guò)當(dāng)前元素在數(shù)組中循環(huán)出來(lái)的索引來(lái)獲取對(duì)應(yīng)視頻的時(shí)間,最后一個(gè)簡(jiǎn)單的計(jì)算進(jìn)度條的方法,(當(dāng)前時(shí)間 / 總時(shí)間)* 100 = 進(jìn)度條的值

注意坑點(diǎn)

:如果在數(shù)組中摻雜了其他的非視頻文件,這里使用ref的方式,就不能根據(jù)索引來(lái)獲取,就得定義唯一的ref,嘿嘿!

到此首頁(yè)功能結(jié)束了,接著實(shí)現(xiàn)詳情頁(yè)的自定義控制條。

html部分:

//視頻中的暫停按鈕
// 控制條的播放和暫停按鈕

//播放進(jìn)度條
//當(dāng)前播放時(shí)間
{{vcCurrentTime}}
//視頻總時(shí)長(zhǎng)
{{item.duration_time}}
//倍速控制
{{speedTime}} 0.5x 1x 1.5x 2x 3x
//音量控制
//全屏播放

css部分忽略了。。。

直接看功能:首先data部分:

vcIsPlay: false, //是否播放
 opcityVal: {
 opacity: '1'
 },
 currentTimeVal: 0, // 當(dāng)前時(shí)間
 vcCurrentTime: '00:00:00', //當(dāng)前時(shí)間格式化
 vcProgress: 0, //進(jìn)度條的綁定時(shí)間
 durationProgress: 0, //當(dāng)前視頻的總時(shí)長(zhǎng)
 speedTime: '1x', //倍速
 voiceProgress: 0 //聲音

暫停和播放:

// 播放和暫停視頻
 controlVideo() {
 let videoObj = this.$refs.videoCon
 this.durationProgress = videoObj[0].duration //總時(shí)間
 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)用提供的兩個(gè)方法即可,然后使用vue的style綁定控制暫停按鈕的顯隱即可,這里的進(jìn)度條,我換了種玩法,同樣是element的滑動(dòng)條組件,只不過(guò)max值我換成了總時(shí)長(zhǎng),單位秒,原因請(qǐng)耐心看下文,嘿嘿!

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

進(jìn)度條部分:

// 獲取時(shí)間
 videoTimeUpdate() {
 let videoObj = this.$refs.videoCon
 let currTime = videoObj[0].currentTime //當(dāng)前時(shí)間
 this.vcProgress = currTime //賦值給進(jìn)度條
 this.vcCurrentTime = this.getFormatVideoTime(currTime)
 console.log(this.vcCurrentTime) //"00:00:27"
 },
 //格式化時(shí)間
 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
 },

這里難點(diǎn)是,我如何進(jìn)行拖動(dòng)進(jìn)度條,來(lái)進(jìn)行控制呢?

別慌,看 代碼:

@change="getNewTime" //element 的滑動(dòng)組件有個(gè)chang事件
 getNewTime(val) {
 let videoObj = this.$refs.videoCon
 console.log(val)
 videoObj[0].currentTime = val
 },

通過(guò)change進(jìn)度條,然后重新賦值給當(dāng)前時(shí)間就搞定了,可以說(shuō)是炒雞舒服了

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

倍速部分:

// 獲取當(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
 }
 },

看圖:

如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條

這里使用的是element的下拉組件,同樣,Video的playbackRate可以直接賦值,控制播放速度

聲音部分:

// 設(shè)置聲音

 getNewVoice(val) {
 let videoObj = this.$refs.videoCon
 let newVc = val / 100 //h6規(guī)定,volume的值必須再0-1之間,比如0.5就是50%的音量,但是進(jìn)度條的值為100,因此這里做個(gè)除法
 videoObj[0].volume = newVc //賦值
 },

我也是使用的滑組件,max值保持默認(rèn)的100,然后滑動(dòng)改變的時(shí)候,把默認(rèn)值除100,比如當(dāng)前滑塊的新值是50,除100后得到的就是【0-1】范圍里的合法值,Video提供的volume值如果不在 0-1之間,就會(huì)報(bào)錯(cuò)

最后是全屏部分:

// 全屏播放
 getFullSceen() {
 let videoObj = this.$refs.videoCon
 videoObj[0].webkitRequestFullScreen()
 },

但是我看到網(wǎng)上還有一種方法是模擬按下f11的全部,如果有興趣也可以了解下!

總結(jié)

因?yàn)橹皼](méi)有很仔細(xì)的搞過(guò)video,所以對(duì)它很多的內(nèi)置屬性和方法不了解,沒(méi)經(jīng)驗(yàn)就害怕,很慌很慌,這就跟談戀愛(ài)似的,哈哈哈,再組長(zhǎng)的支持和鼓勵(lì)下,我大膽的嘗試了,成功后,這次經(jīng)驗(yàn)給了我很大信心,感覺(jué)以后寫(xiě)其他沒(méi)做過(guò)的功能,都不會(huì)慌了,畢竟難的部分寫(xiě)elementUi的大佬們都給寫(xiě)好了,可以說(shuō)是站在巨人的肩膀上,哈哈哈!膜拜大佬,以后還得多多努力了。

以上就是關(guān)于如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條的內(nèi)容,如果你們有學(xué)習(xí)到知識(shí)或者技能,可以把它分享出去讓更多的人看到。


分享標(biāo)題:如何實(shí)現(xiàn)vue項(xiàng)目中自定義video視頻控制條
分享路徑:http://weahome.cn/article/jssgjs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部