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

解决:移动端H5的<video>初始化拿不到总时长

移动端

在<video>的初始化后,会调用如下事件。

@canplay="canplay"

解决方案:<video>添加自动播放属性:

autoplay="autoplay"

然后这个方法里,用js在0.01秒后主动关闭播放,接着在0.1秒之后获取视频总长度即可(这里用0.01秒有几率失败)。

这样连视频的预览图都省了,哈哈哈😁😁😁😁😁。。。。

    canplay() {this.getSize();//表示视频已经加载好了//这可以获取视频真是高度和宽度,console.log("视频已准备好了,可以播放,宽度:" + this.videoWidth + ",高度:" + this.videoHeight)setTimeout(()=>{this.playPause();setTimeout(()=>{this.getSize();},100);},10);},

pc端

pc端<video>的监听事件没什么问题,一共有这么多种监听事件。

 <video ref="video"controlsautoplay="autoplay"@loadedmetadata="loadedmetadata"@canplay="canplay"@waiting="waiting"@timeupdate="timeupdate"@play="play"@pause="pause"@ended="ended">   canplay() {//表示视频已经加载好了//这可以获取视频真是高度和宽度,},waiting() {//转圈的时候才会调用,秒加载好像不会触发console.log("加载中");},loadedmetadata() {this.totalTime = this.$refs.video.duration;console.log("获取视频总时间长度:" + this.formatTime(this.totalTime));},play() {this.displayStatus = true;console.log("开始播放");},pause() {console.log("暂停播放");this.displayStatus = false;},ended() {console.log("播放结束");},timeupdate() { //播放的时间戳更新this.nowTime = this.$refs.video.currentTimethis.totalTime = this.$refs.video.duration},this.$refs.video.onloadstart =(e)=> {//在浏览器开始寻找指定视频/音频(audio/video)触发console.log("onloadstart",e)}this.$refs.video.onprogress =(e)=> {//在浏览器下载指定的视频/音频(audio/video)时触发console.log("onprogress",e)}this.$refs.video.ondurationchange =(e)=> {//事件在视频/音频(audio/video)的时长发生变化时触发console.log("ondurationchange",e)}this.$refs.video.onloadeddata =(e)=> {//事件在当前帧的数据加载完成且还没有足够的数据播放视频/音频(audio/video)的下一帧时触发console.log("onloadeddata",e)}this.$refs.video.oncanplaythrough =(e)=> {//可以正常播放且无需停顿和缓冲时触发console.log("oncanplaythrough",e)}

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

相关文章:

  • 百度云上传身份证获取身份信息封装
  • vscode 上cmake 版本过低
  • OS-08-事件驱动:C10M是如何实现的?
  • mysql 主从同步排查和处理 Slave_IO、Slave_SQL
  • 基于解析法和遗传算法相结合的配电网多台分布式电源降损配置(Matlab实现)
  • 07mysql查询语句之子查询
  • 笙默考试管理系统-MyExamTest(22)
  • Windows 不同方式打开的cmd/dos窗口属性配置不同
  • 性能优化-webpack配置gzip
  • RabbitMQ 教程 | 第3章 客户端开发向导
  • 基于深度学习的CCPD车牌检测系统(PyTorch+Pyside6+YOLOv5模型)
  • input元素中的form属性有什么用?
  • 【数据结构篇C++实现】- 特殊的线性表 - 串
  • DevOps系列文章 之 Springboot单元测试
  • 04 linux之C 语言高级编程
  • 深入学习 Redis - Stream、Geospatial、HyperLogLog、Bitmap、Bitfields 类型扩展
  • Windows11+Opencv+Clion编译源码
  • 【机器学习】Cost Function
  • 【黑马头条之内容安全第三方接口】
  • 回归预测 | MATLAB实现GRNN广义回归神经网络多输入单输出回归预测(多指标,多图)
  • STM32 HAL库函数——HAL_UART_RxCpltCallback()详解
  • 前端调用合约如何避免出现transaction fail
  • 选择器的使用
  • 软考A计划-系统集成项目管理工程师-项目干系人管理-上
  • F5 LTM 知识点和实验 2-负载均衡基础概念
  • 安全学习DAY08_算法加密
  • OpenCloudOS 与PolarDB全面适配
  • 如何在Linux系统中使用yum命令安装MySQL
  • 在Ail Linux中手动配置IPv6
  • TCP如何保证服务的可靠性