首先贴一下插件的配置项:
playerOptions: {
// playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
autoplay: false, // 如果true,浏览器准备好时开始回放。
muted: false, // 默认情况下将会消除任何音频。
loop: false, // 导致视频一结束就重新开始。
preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
language: 'zh-CN',
aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
sources: [
{
src: '', // 路径
type: 'video/mp4' // 类型
}
],
poster: '', // 你的封面地址
width: document.documentElement.clientWidth,
notSupportedMessage: '', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
controlBar: {
// timeDivider: true,
// durationDisplay: true,
// remainingTimeDisplay: false,
fullscreenToggle: true // 全屏按钮
}
}
在开发业务过程中使用vue-video-player插件,视频的地址是由后端接口返回的,将视频地址直接赋值给playerOptions中的src是不行的,播放器会报找不到资源的错误,尝试使用require引入地址也不行。
最后发现是需要后端写一个视频播放返回流的接口,并且拼接完整的带ip的路径。
this.playerOptions.sources[0].src =
ip +
'/file/downloadVideo?id=' +
res.id +
'&ossUrl=' +
res.videoUrl +
'&fileName=' +
res.videoName
由于业务中需要计算视频播放的次数,一开始是通过每调用一次这个视频播放返回流的接口就增加一次播放量,后来发现每次刷新页面的时候视频播放次数都会增加,猜测是由于每次刷新页面赋值的时候就相当于调用了接口,导致播放次数增加。
最后后端重新写了一个专门用来增加播放量的接口,解决了问题。