npm install vue-video-player --save
import VideoPlayer from 'vue-video-player'
window.videojs = VideoPlayer.videojs //不设置这个,引用语言会报错
require('vue-video-player/src/custom-theme.css')
require('video.js/dist/video-js.min.css')
require('video.js/dist/lang/zh-CN.js') //必须引用,后面设置语言才会生效
Vue.use(VideoPlayer)
<video-player
class="vjs-custom-skin videoPlayer"
ref="videoPlayer"
:playsinline="true"
:options="playerOptions"
style="width:100px;height:100px;"
></video-player>
vjs-custom-skin 不加这个类目播放按钮不居中
props: {
//视频源地址
src: {
type: String,
default:
"https://aliyun.oss.careyshop.cn/uploads/files/20191113/9bbf7ac9-a452-445b-8152-4443bc3505e8.mp4?type=aliyun"
},
//视频格式
videoType: {
type: String,
default: "video/mp4"
},
//封面
poster: {
type: String,
default: ""
}
},
computed: {
playerOptions() {
return {
playbackRates: [0.5, 1.0, 1.5, 2.0, 3.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: [
{
type: this.videoType,
src: this.src
}
],
poster: this.poster, //你的封面地址
// techOrder: ['flash'], // 使用flase播放,可以播放flv格式的文件
width: document.documentElement.clientWidth,
notSupportedMessage: "此视频暂无法播放,请稍后再试", //允许覆盖Video.js无法播放媒体源时显示的默认信息。
controlBar: {
timeDivider: true, //当前时间和持续时间的分隔符
durationDisplay: true, //显示持续时间
remainingTimeDisplay: false, //是否显示剩余时间功能
fullscreenToggle: true //全屏按钮
}
};
}
},