vue-video-player重载问题处理

版本

vue 2.6.10
vue-video-player 5.0.2
element ui 2.5.16

场景

公司业务需要,需要做成以下效果:

在这里插入图片描述
要求每个视频可以勾选,也可以点击全选选择全部视频。
页面通过el-checkbox-group+el-checkbox+video进行布局,通过循环数据源将复选框与视频进行绑定。
开发过程中发现,当勾选时,会导致页面全部视频资源进行重载。
查看vue-video-player源码中的视频资源加载方法,发现其中的watch方法是导致重载的原因
在这里插入图片描述
此处深度监听视频数据源options的改变,若改变,则重新加载。而当我们勾选复选框时,就会触发此方法,导致视频重载。

问题解决

针对此问题,根据当前业务场景,我这边将该方法做了优化,只有当改变前后的options中的sources不一致时才执行重载方法,否则不执行。

// vue-video-player
import { videoPlayer } from 'vue-video-player/src'
import 'vue-video-player/node_modules/video.js/dist/video-js.css'
import 'vue-video-player/src/custom-theme.css'
// 重写vue-video-player watch
const repeatVideo = function (videoPlayer) {
  videoPlayer.watch.options.handler = (options, old) => {
    if (JSON.stringify(old.sources) === JSON.stringify(options.sources)) return
    videoPlayer.methods.dispose(() => {
      if (options && options.sources && options.sources.length) {
        videoPlayer.methods.initialize()
      }
    })
  }
  return videoPlayer
}
// 重新注册
components: { VideoPlayer: repeatVideo(videoPlayer) },

其他问题记录

vue-video-player重置方法

this.$refs['videoPlayer'].player.src([this.sources]) // 重置

目前发现,当player.src()接受一个数据对象时,mkv格式的视频会出现重置失败的问题,改为数组即可解决。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值