电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

vue項目中自定義video視頻控制條的實現代碼

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

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

首頁效果圖:

vue項目中自定義video視頻控制條的實現代碼

需求描述:

當鼠標放在圖片上的時候,自動播放視頻,并顯示預覽進度條,當鼠標移開,顯示預覽圖片,再次hover圖片,繼續上次播放

視頻詳情頁的效果圖:

vue項目中自定義video視頻控制條的實現代碼

需求描述:

能自定義的暫停和播放 模仿進度條可實現拖拽播放速度 顯示當前時間 能選擇倍速 能控制聲音 能全屏播放

接下來一步步的實現

首先康康首頁的,上結構代碼:

<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://www.hdgsjgj.cn/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,判斷用戶鼠標事件,切換圖片和視頻。

2.video需要通過video來獲取他實例來進行dom操作,video的鼠標移入和滑出分類是控制視頻的播放和停止,play和pause是video的內置方法。 更多方法見這里哦~

3.這里的進度條使用的是element的滑動條組件,默認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顯示的時候和圖片的寬高一致,不然就會出現圖片大,視頻小的情況,如圖:

vue項目中自定義video視頻控制條的實現代碼

邏輯部分:

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

這里使用video 的timeupdate內置方法獲取當前播放時間,并獲取當前的的dom元素,這里的videoObj打印出來是個數組:

vue項目中自定義video視頻控制條的實現代碼

我們通過當前元素在數組中循環出來的索引來獲取對應視頻的時間,最后一個簡單的計算進度條的方法,(當前時間 / 總時間)* 100 = 進度條的值

注意坑點

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

到此首頁功能結束了,接著實現詳情頁的自定義控制條。

html部分:

<div class='detali_box_img video-media'> <div class='video-example'> <video :src='http://www.hdgsjgj.cn/bcjs/item.video_file' loop='loop' preload='auto' @timeupdate='videoTimeUpdate' @click='controlVideo' ref='videoCon'> 您的瀏覽器不支持 video 標簽。 </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> //播放進度條 <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> //當前播放時間 <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, // 當前時間 vcCurrentTime: ’00:00:00’, //當前時間格式化 vcProgress: 0, //進度條的綁定時間 durationProgress: 0, //當前視頻的總時長 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’ },

直接調用提供的兩個方法即可,然后使用vue的style綁定控制暫停按鈕的顯隱即可,這里的進度條,我換了種玩法,同樣是element的滑動條組件,只不過max值我換成了總時長,單位秒,原因請耐心看下文,嘿嘿!

vue項目中自定義video視頻控制條的實現代碼

進度條部分:

// 獲取時間 videoTimeUpdate() { let videoObj = this.$refs.videoCon let currTime = videoObj[0].currentTime //當前時間 this.vcProgress = currTime //賦值給進度條 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 },

這里難點是,我如何進行拖動進度條,來進行控制呢?

別慌,看 代碼:

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

通過change進度條,然后重新賦值給當前時間就搞定了,可以說是炒雞舒服了

vue項目中自定義video視頻控制條的實現代碼

倍速部分:

// 獲取當前播放的速度 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視頻控制條的實現代碼

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

聲音部分:

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

我也是使用的滑組件,max值保持默認的100,然后滑動改變的時候,把默認值除100,比如當前滑塊的新值是50,除100后得到的就是【0-1】范圍里的合法值,Video提供的volume值如果不在 0-1之間,就會報錯

最后是全屏部分:

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

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

總結

因為之前沒有很仔細的搞過video,所以對它很多的內置屬性和方法不了解,沒經驗就害怕,很慌很慌,這就跟談戀愛似的,哈哈哈,再組長的支持和鼓勵下,我大膽的嘗試了,成功后,這次經驗給了我很大信心,感覺以后寫其他沒做過的功能,都不會慌了,畢竟難的部分寫elementUi的大佬們都給寫好了,可以說是站在巨人的肩膀上,哈哈哈!膜拜大佬,以后還得多多努力了。

到此這篇關于vue項目中自定義video視頻控制條的實現代碼的文章就介紹到這了,更多相關vue 自定義video視頻控制條內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 压砖机、液压制砖机、静压砖机、环保砖机生产厂家—杜甫机械 | 回转窑-水泥|石灰|冶金-巩义市瑞光金属制品有限责任公司 | 生态板-实木生态板-生态板厂家-源木原作生态板品牌-深圳市方舟木业有限公司 | EPK超声波测厚仪,德国EPK测厚仪维修-上海树信仪器仪表有限公司 | 网优资讯-为循环资源、大宗商品、工业服务提供资讯与行情分析的数据服务平台 | 云南成人高考_云南成考网| 金属回收_废铜废铁回收_边角料回收_废不锈钢回收_废旧电缆线回收-广东益夫金属回收公司 | 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | DWS物流设备_扫码称重量方一体机_快递包裹分拣机_广东高臻智能装备有限公司 | 存包柜厂家_电子存包柜_超市存包柜_超市电子存包柜_自动存包柜-洛阳中星 | 剪刃_纵剪机刀片_分条机刀片-南京雷德机械有限公司 | 杰福伦_磁致伸缩位移传感器_线性位移传感器-意大利GEFRAN杰福伦-河南赉威液压科技有限公司 | 辽宁资质代办_辽宁建筑资质办理_辽宁建筑资质延期升级_辽宁中杭资质代办 | 老房子翻新装修,旧房墙面翻新,房屋防水补漏,厨房卫生间改造,室内装潢装修公司 - 一修房屋快修官网 | 泉州陶瓷pc砖_园林景观砖厂家_石英砖地铺石价格 _福建暴风石英砖 | QQ房产导航-免费收录优秀房地产网站_房地产信息网 | 卫生纸复卷机|抽纸机|卫生纸加工设备|做卫生纸机器|小型卫生纸加工需要什么设备|卫生纸机器设备多少钱一台|许昌恒源纸品机械有限公司 | 元拓建材集团官方网站 | 老城街小面官网_正宗重庆小面加盟技术培训_特色面馆加盟|牛肉拉面|招商加盟代理费用多少钱 | 合肥风管加工厂-安徽螺旋/不锈钢风管-通风管道加工厂家-安徽风之范 | 长沙网站建设制作「网站优化推广」-网页设计公司-速马科技官网 | 酒瓶_酒杯_玻璃瓶生产厂家_徐州明政玻璃制品有限公司 | 水厂污泥地磅|污泥处理地磅厂家|地磅无人值守称重系统升级改造|地磅自动称重系统维修-河南成辉电子科技有限公司 | 超声波_清洗机_超声波清洗机专业生产厂家-深圳市好顺超声设备有限公司 | 哈希PC1R1A,哈希CA9300,哈希SC4500-上海鑫嵩实业有限公司 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 立式_复合式_壁挂式智能化电伴热洗眼器-上海达傲洗眼器生产厂家 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 多功能真空滤油机_润滑油全自动滤油机_高效真空滤油机价格-重庆润华通驰 | 动力配电箱-不锈钢配电箱-高压开关柜-重庆宇轩机电设备有限公司 聚天冬氨酸,亚氨基二琥珀酸四钠,PASP,IDS - 远联化工 | 微型实验室真空泵-无油干式真空泵-微型涡旋耐腐蚀压缩机-思科涡旋科技(杭州)有限公司 | 立式_复合式_壁挂式智能化电伴热洗眼器-上海达傲洗眼器生产厂家 理化生实验室设备,吊装实验室设备,顶装实验室设备,实验室成套设备厂家,校园功能室设备,智慧书法教室方案 - 东莞市惠森教学设备有限公司 | 企小优-企业数字化转型服务商_网络推广_网络推广公司 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 飞利浦LED体育场灯具-吸顶式油站灯-飞利浦LED罩棚灯-佛山嘉耀照明有限公司 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 杭州荣奥家具有限公司-浙江办公家具,杭州办公家具厂 | 泥浆在线密度计厂家-防爆数字压力表-膜盒-远传压力表厂家-江苏大亚自控设备有限公司 | 济南展厅设计施工_数字化展厅策划设计施工公司_山东锐尚文化传播有限公司 | 悬浮拼装地板_幼儿园_篮球场_悬浮拼接地板-山东悬浮拼装地板厂家 | 校车_校车价格_19座幼儿园校车_幼儿园校车_大鼻子校车 | 上海单片机培训|重庆曙海培训分支机构—CortexM3+uC/OS培训班,北京linux培训,Windows驱动开发培训|上海IC版图设计,西安linux培训,北京汽车电子EMC培训,ARM培训,MTK培训,Android培训 |