日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

vue項目中自定義video視頻控制條的實現(xiàn)代碼

瀏覽:202日期:2023-01-24 10:56:22

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

首頁效果圖:

vue項目中自定義video視頻控制條的實現(xiàn)代碼

需求描述:

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

視頻詳情頁的效果圖:

vue項目中自定義video視頻控制條的實現(xiàn)代碼

需求描述:

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

接下來一步步的實現(xiàn)

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

<div @mouseover='play(item3.images_id)' @mouseout='pause(item3.images_id)'> <img v-lazy='item3.picture' alt='' v-show='id != item3.images_id'> <video ref='videoAll' onMouseOver='this.play()' :src='http://m.b3g6.com/bcjs/item3.short_video' @timeupdate='commonVideoUpdata(index)' onMouseOut='this.pause()' muted loop='loop'> </video> </div> <div 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)圖片大,視頻小的情況,如圖:

vue項目中自定義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ù)組:

vue項目中自定義video視頻控制條的實現(xiàn)代碼

我們通過當(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='http://m.b3g6.com/bcjs/item.video_file' loop='loop' preload='auto' @timeupdate='videoTimeUpdate' @click='controlVideo' ref='videoCon'> 您的瀏覽器不支持 video 標(biāo)簽。 </video> </div> //視頻中的暫停按鈕 <div @click='controlVideo' :style='[opcityVal]'></div> // 控制條的播放和暫停按鈕 <div class='control-play'> <p @click='controlVideo'> <span v-show='!vcIsPlay'></span> <span 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 @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 @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值我換成了總時長,單位秒,原因請耐心看下文,嘿嘿!

vue項目中自定義video視頻控制條的實現(xiàn)代碼

進(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)前時間就搞定了,可以說是炒雞舒服了

vue項目中自定義video視頻控制條的實現(xiàn)代碼

倍速部分:

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

看圖:

vue項目中自定義video視頻控制條的實現(xiàn)代碼

這里使用的是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)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美va天堂在线| 99香蕉国产精品偷在线观看| 亚洲久久一区| 日韩国产欧美| 欧美一区影院| 日韩中文字幕区一区有砖一区| www成人在线视频| 久久男人av| 91精品日本| 青青国产精品| 日韩精品第二页| 激情综合网址| 久久久国产精品一区二区中文| 国产精品115| 国产精品一区二区av日韩在线| 久久久久美女| 99久久婷婷这里只有精品| 吉吉日韩欧美| 日本午夜大片a在线观看| 丁香婷婷久久| 亚洲一级少妇| 久久激情婷婷| 欧美特黄一区| 国产精品丝袜xxxxxxx| 日韩影院免费视频| 香蕉久久一区| 老司机精品视频在线播放| 免费精品视频在线| 午夜亚洲福利| 国产欧美高清视频在线| 色婷婷成人网| 精品美女视频 | 久久久9色精品国产一区二区三区| 久久一区欧美| 91av亚洲| 国产一区日韩一区| 中文字幕av一区二区三区四区| 亚洲精选91| 亚洲一二av| 麻豆精品少妇| 欧美精品激情| 国产精品主播| 欧美在线亚洲| 久久精品99国产国产精| 成人日韩av| 亚洲色诱最新| 九九久久国产| 特黄毛片在线观看| 亚洲区第一页| 久久久久免费av| 国产日韩一区| 一本一本久久| 在线看片国产福利你懂的| 亚洲二区三区不卡| 国产精品一区二区三区av麻| 国产高清一区二区| 国产精品一区三区在线观看| 精品日韩视频| 国产精品二区影院| 亚洲欧美激情诱惑| 成人啊v在线| 荡女精品导航| 欧美久久香蕉| 99久久九九| 亚洲三级欧美| 免费一区二区三区在线视频| 天堂成人免费av电影一区| 亚洲涩涩在线| 清纯唯美亚洲综合一区| 国产亚洲毛片在线| 99精品在线观看| 都市激情国产精品| 美女精品久久| 麻豆91在线播放| 久久超碰99| 国产精品久久久久久久久免费高清 | 欧美精品日日操| 国产精品乱战久久久| 欧美一区二区三区久久精品| 免费看精品久久片| 久久av一区| 亚洲福利一区| 99久久激情| 欧美性感美女一区二区| 久久国产亚洲| 精品日韩视频| 国产一区二区三区91| 日本成人中文字幕在线视频| 亚洲欧洲av| 亚洲一二av| 免费在线日韩av| 九九99久久精品在免费线bt| 99久久激情| 日本在线一区二区三区| 精品国产午夜肉伦伦影院| 99久久婷婷| 日产欧产美韩系列久久99| 成人综合一区| 久久亚洲图片| 日韩欧美三级| 五月亚洲婷婷 | 日韩久久精品网| 天堂成人免费av电影一区 | 麻豆精品视频在线观看| 欧美福利一区| 精品黄色一级片| 亚洲另类黄色| 美女精品一区二区| 欧美日韩视频| 国产福利电影在线播放| 亚洲欧美专区| 免费久久精品| av在线最新| 国产精品免费大片| 亚洲一区二区日韩| 久久精品国产大片免费观看| 国内在线观看一区二区三区| 日av在线不卡| 欧洲av一区二区| 久久精品国产网站| 久久精品超碰| 亚洲精品在线二区| 天堂资源在线亚洲| 国产999精品在线观看| 日韩av在线播放中文字幕| 99国产精品| 欧美日韩国产高清电影| 人人精品亚洲| 日韩在线观看不卡| 日韩理论片av| 日韩精品首页| 久久国产直播| 999久久久精品国产| 超级白嫩亚洲国产第一| 国内自拍视频一区二区三区| 国产精品va视频| 美女精品久久| 久久激五月天综合精品| 日韩av黄色在线| 日韩av网站在线观看| 国产亚洲久久| 色婷婷综合网| 亚洲天堂黄色| 日韩中文字幕av电影| 日韩一区中文| 激情综合婷婷| 日韩精品一区二区三区免费观影 | 国产午夜精品一区在线观看| 日本a级不卡| 国产三级一区| 国产精品毛片久久| 999国产精品999久久久久久| 99在线观看免费视频精品观看| 亚洲一本视频| 欧美视频一区| 国内精品99| 国产福利资源一区| 亚洲欧美日韩国产一区| 国产精品黄色片| 91高清一区| 男女男精品网站| 精品美女在线视频| 一区二区三区网站| 日韩电影免费在线观看| 日韩av一区二区在线影视| 久久国产毛片| 国产精品白浆| 一区二区国产在线| 久久毛片亚洲| 亚洲婷婷丁香| 成人欧美一区二区三区的电影| 一区福利视频| 国产亚洲高清在线观看| 亚洲一区国产一区| 国产精品v日韩精品v欧美精品网站| 桃色av一区二区| 中文一区一区三区免费在线观 | 综合一区二区三区| 日本伊人久久| 国产欧美午夜| 麻豆国产一区| 欧美精品一线| 久久蜜桃资源一区二区老牛| 四虎精品永久免费| 婷婷激情一区| 免费人成网站在线观看欧美高清| 日韩a一区二区| 日韩久久99| 精品一区亚洲| 国产亚洲精品v| 亚洲黄页一区| 91精品啪在线观看国产18| 国产精品美女午夜爽爽| 国产精品一页| 视频一区中文字幕| 亲子伦视频一区二区三区| 亚洲国产成人二区| 精品一区二区三区中文字幕在线| 在线一区欧美| 日韩欧美另类一区二区|