vue-video-play使用之播放hls格式视频

开发准备

vue-video-player和videojs-contrib-hls

复制代码
npm i vue-video-player
npm i videojs-contrib-hls

引入

js 复制代码
import { videoPlayer } from 'vue-video-player'
import 'videojs-contrib-hls'

使用

html 复制代码
     <videoPlayer
                v-else
                id="jsVideo"
                ref="videoPlayer"
                :playsinline="true"
                :options="playerOptions">
      </videoPlayer>
js 复制代码
playerOptions: {
    sources: [{
		type: 'application/x-mpegURL',
		src: 'https:xxxxx..m3u8' // 这里写自己的视频地址就可以
	}],
    autoplay: true,
    loop: true,
    poster: '',
    controlBar: {
        fullscreenToggle: false,
        playToggle: false,
        volumePanel: false,
    },
},

video.js 播放器的默认结构如下所示:

复制代码
Player
├── MediaLoader (has no DOM element)
├── PosterImage
├── TextTrackDisplay
├── LoadingSpinner
├── BigPlayButton
├── LiveTracker (has no DOM element)
├─┬ ControlBar
│ ├── PlayToggle
│ ├── VolumePanel
│ ├── CurrentTimeDisplay (hidden by default)
│ ├── TimeDivider (hidden by default)
│ ├── DurationDisplay (hidden by default)
│ ├─┬ ProgressControl (hidden during live playback, except when liveui: true)
│ │ └─┬ SeekBar
│ │   ├── LoadProgressBar
│ │   ├── MouseTimeDisplay
│ │   └── PlayProgressBar
│ ├── LiveDisplay (hidden during VOD playback)
│ ├── SeekToLive (hidden during VOD playback)
│ ├── RemainingTimeDisplay
│ ├── CustomControlSpacer (has no UI)
│ ├── PlaybackRateMenuButton (hidden, unless playback tech supports rate changes)
│ ├── ChaptersButton (hidden, unless there are relevant tracks)
│ ├── DescriptionsButton (hidden, unless there are relevant tracks)
│ ├── SubtitlesButton (hidden, unless there are relevant tracks)
│ ├── CaptionsButton (hidden, unless there are relevant tracks)
│ ├── SubsCapsButton (hidden, unless there are relevant tracks)
│ ├── AudioTrackButton (hidden, unless there are relevant tracks)
│ ├── PictureInPictureToggle
│ └── FullscreenToggle
├── ErrorDisplay (hidden, until there is an error)
├── TextTrackSettings

controlBar组件的说明

playToggle, // 播放暂停按钮

volumeMenuButton,// 音量控制

currentTimeDisplay,// 当前播放时间

timeDivider, // '/' 分隔符

durationDisplay, // 总时间

progressControl, // 点播流时,播放进度条,seek控制

liveDisplay, // 直播流时,显示LIVE

remainingTimeDisplay, // 当前播放时间

playbackRateMenuButton, // 播放速率,当前只有html5模式下才支持设置播放速率

fullscreenToggle // 全屏控制

相关推荐
帧栈1 小时前
开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
前端·vue.js
max5006001 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
excel1 小时前
使用函数式封装绘制科赫雪花(Koch Snowflake)
前端
我命由我123452 小时前
软件开发 - 避免过多的 if-else 语句(使用策略模式、使用映射表、使用枚举、使用函数式编程)
java·开发语言·javascript·设计模式·java-ee·策略模式·js
萌萌哒草头将军2 小时前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
AALoveTouch3 小时前
大麦APP抢票揭秘
javascript
持久的棒棒君3 小时前
启动electron桌面项目控制台输出中文时乱码解决
前端·javascript·electron
小离a_a4 小时前
使用原生css实现word目录样式,标题后面的...动态长度并始终在标题后方(生成点线)
前端·css
郭优秀的笔记5 小时前
抽奖程序web程序
前端·css·css3
尚学教辅学习资料5 小时前
Vue3从入门到精通: 4.5 数据持久化与同步策略深度解析
vue·数据持久化