1.先引入npm
npminstallvideo.js--save
npminstallvideojs-contrib-hls--save
2.在main.js中引入
import 'video.js/dist/video-js.css';
import videojs from 'video.js';
import 'videojs-contrib-hls';
3.在html中或vue中找到你想用的地方写标签
id和class必须要写哇
<video id="singleVideo" class="video-js vjs-default-skin vjs-big-play-centered " loop autoplay muted controls >
</video>
4. 在mounted里面写地址和宽高
let singlePlayer = videojs("singleVideo", {
autoplay: true,//自动播放
controls: true,//控件显示
width: "500",//视频框宽度
height: "264",//视频框高度
});
let res ="视频路径.m3u8";
if (res) {
singlePlayer.src({ src: res, type: "application/x-mpegURL" });//type也必须要写哦
}
5.可能会报错的一个问题The element or ID supplied is not valid
我没找到原因,但是找到一个办法解决
延迟加载,用倒计时
setTimeout(()=>{
},6000)
这样的话就没有问题了
其他报错可以参考一下其他博主https://segmentfault.com/a/1190000025140095
6.储存一点video属性
autoplay 视频就绪,自动播放
controls 向用户展示控件,比如播放按钮、全屏
height 视频播放器的高度
width 视频播放器的宽度
loop 视频循环播放
muted 静音
poster 视频下载时展示的图片
preload 预加载
src 视频的url