当前位置: 首页 > news >正文

vue3+vant实现视频播放(含首次禁止进度条拖拽,视频看完后恢复,保存播放视频进度,刷新及下次进入继续播放,判断视频有无全部看完等)

1、效果图

2、

<div><videocontrolsclass="video_player"ref="videoPlayer":src="videoSrc"@timeupdate="handleTimeUpdate"@play="onPlay"@pause="onPause"@ended="onVideoEnded"></video><!--添加遮罩层视频第一次观看不支持快进,已观看过的内容重复观看支持快进。--><div v-if="videoPlayEnd == false" class="cover"></div>
</div><div class="right_box" v-if="videoPlayEnd == true"><img class="img_style" src="@/assets/image/已看完.png" /><div class="text_right">已看完</div>
</div>
<div class="right_box" v-if="videoPlayEnd == false"><img class="img_style" src="@/assets/image/未看完.png" /><div class="text2_right">未看完</div>
</div>const videoPlayEnd = ref(false) //视频播放结束标识
const lastTime = ref(0) //视频上次播放的时间
//视频播放
const onPlay = () => {console.log('视频播放')
}
//视频暂停
const onPause = () => {console.log('视频暂停')
}
//播放结束
const onVideoEnded = () => {console.log('播放结束')videoPlayEnd.value = true
}
const handleTimeUpdate = () => {if (videoPlayer.value) {const currentTime = videoPlayer.value.currentTime //当前播放的时间lastTime.value = currentTime //保存当前播放时间localStorage.setItem('videoTime', lastTime.value)}
}onMounted(() => {//实现保存视频进度,下次进来继续播放const savedTime = localStorage.getItem('videoTime')if (savedTime) {//检查是否存在保存的时间videoPlayer.value.currentTime = parseFloat(savedTime) //转化成浮点数}handleTimeUpdate()
})

 

http://www.lryc.cn/news/474685.html

相关文章:

  • 情感强度分析:精确衡量文本情感强弱的 AI 技术
  • 工厂方法模式与抽象工厂模式
  • 「Math」初等数学知识点大纲(占位待处理)
  • 百元高性价比头戴式降噪耳机选哪款?四款平价性价比品牌别错过!
  • vue3 setup写不写到标签上的区别
  • 【论文解读】EdgeYOLO:一种边缘实时目标检测器(附论文地址)
  • xlwings,让excel飞起来!
  • C语言学习,标准库 <stddef.h>
  • PyQt5实战——操作台打印重定向,主界面以及stacklayout使用(四)
  • React + Vite + TypeScript + React router项目搭建教程
  • 【ShuQiHere】️ 如何启用 SSH 服务
  • 【自动化测试】APP UI 自动化(安卓)-本地环境搭建
  • java毕业设计之基于Bootstrap的常州地方旅游管理系统的设计与实现(springboot)
  • 《机甲崛起》
  • Windows10:Linux Reader
  • 一、k8s快速入门之学习Kubernetes组件基础
  • PostgreSQL 到 PostgreSQL 数据迁移同步
  • RestTemplate 常用方法(提供了多种方法来发送 HTTP 请求)
  • 常量和变量
  • Go语言的使用
  • 详解CRC校验原理以及FPGA实现
  • 企业如何通过架构蓝图实现数字化转型
  • React第十三章(useTransition)
  • IDEA使用Maven Helper查看整个项目的jar冲突
  • uniapp项目 存储数据到手机本地
  • 景联文科技医疗数据处理平台:强化医疗数据标注与管理,推动医疗数字化新篇章
  • vue使用高德地图实现轨迹显隐
  • Maven(20) 如何使用Maven进行版本管理?
  • AWS RDS MySQL内存使用
  • Vue指令:v-else、v-else-if