Vue?監(jiān)聽視頻播放時長的實例代碼
更新時間:2024年10月17日 10:56:48 作者:Monly21
本文介紹了如何通過源碼實現(xiàn)對視頻實時時長、播放時長和暫停時長的監(jiān)聽,詳細闡述了相關(guān)技術(shù)的應(yīng)用方法,幫助開發(fā)者更好地掌握視頻監(jiān)控技術(shù),提高用戶體驗
1、源碼
<template> <el-dialog class="videoBox" :title="title" :visible.sync="visible" width="40%" :before-close="handleClose" :close-on-click-modal="false" :close-on-press-escape="false"> <video id="video" controls preload autoplay="autoplay" style="width: 100%" @canplay="getVideoDur"> <source :src="videoUrl" type="video/mp4"> </video> </el-dialog> </template> <script> export default { name: 'VideoPlayBack', data() { return { // 標題 title: null, // 是否顯示彈框 visible: false, // 視頻地址 videoUrl: null } }, methods: { /** * 初始化視頻 */ initVideo() { this.$nextTick(() => { let myVideo = document.getElementById('video') myVideo.pause() myVideo.load() }); }, /** * 監(jiān)聽視頻 */ getVideoDur() { //監(jiān)聽播放時間 var video = document.getElementById("video"); // //使用事件監(jiān)聽方式捕捉事件 // video.addEventListener("timeupdate", function () { // var timeDisplay = Math.floor(video.currentTime); // var duration = Math.floor(video.duration); // console.log("總時長", duration); // console.log("當前播放的時長", timeDisplay); // }, false); // 監(jiān)聽視頻播放 // video.addEventListener("play", function () { // var duration = Math.floor(video.duration); // console.log("總時長", duration); // var timeDisplay = Math.floor(video.currentTime); // console.log("視頻開始時長", timeDisplay); // }) // 監(jiān)聽視頻暫停 video.addEventListener("pause", function () { var duration = Math.floor(video.duration); console.log("總時長", duration); var timeDisplay = Math.floor(video.currentTime); console.log("視頻結(jié)束時長", timeDisplay); }) }, /** * 關(guān)閉彈框 */ handleClose() { this.videoUrl = null this.visible = false }, } } </script> <style> .videoBox .el-dialog__header { background-color: #000000; } .videoBox .el-dialog__header .el-dialog__title { color: #fff; } .videoBox .el-dialog__body { padding: 0 !important; background-color: #000000; } </style>
2、監(jiān)聽視頻實時時長
video.addEventListener("timeupdate", function () { var timeDisplay = Math.floor(video.currentTime); var duration = Math.floor(video.duration); console.log("總時長", duration); console.log("當前播放的時長", timeDisplay); }, false);
3、監(jiān)聽視頻播放時長
video.addEventListener("play", function () { var duration = Math.floor(video.duration); console.log("總時長", duration); var timeDisplay = Math.floor(video.currentTime); console.log("視頻開始時長", timeDisplay); })
4、監(jiān)聽視頻暫停時長
video.addEventListener("pause", function () { var duration = Math.floor(video.duration); console.log("總時長", duration); var timeDisplay = Math.floor(video.currentTime); console.log("視頻結(jié)束時長", timeDisplay); })
到此這篇關(guān)于Vue 監(jiān)聽視頻播放時長的實例代碼的文章就介紹到這了,更多相關(guān)vue播放時長內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Vue不能監(jiān)聽(watch)數(shù)組變化的解決方法
本文主要介紹了Vue不能監(jiān)聽(watch)數(shù)組變化的解決方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09vue3?騰訊地圖設(shè)置簽到范圍并獲取經(jīng)緯度的實現(xiàn)代碼
本文給大家介紹vue3?騰訊地圖設(shè)置簽到范圍并獲取經(jīng)緯度的實現(xiàn)代碼,本文通過示例代碼給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧2022-05-05vue2?使用echarts實現(xiàn)地圖點擊進入下一層級+點擊空白處回退功能
這篇文章主要介紹了vue2?使用echarts實現(xiàn)地圖點擊進入下一層級+點擊空白處回退,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2024-05-05