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 // 全屏控制

相关推荐
遇见你...22 分钟前
TypeScript
前端·javascript·typescript
Highcharts.js28 分钟前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
阿正的梦工坊4 小时前
JavaScript 微任务与宏任务完全指南
开发语言·javascript·ecmascript
懂懂tty4 小时前
CRA 迁移 Rspack(实战)
前端·架构
小码哥_常5 小时前
Kotlin 助力 Android 启动“大提速”
前端
GreenTea5 小时前
AI 时代,工程师的不可替代性在哪里
前端·人工智能·后端
Jagger_6 小时前
能不能别再弄低代码害人了
前端
朦胧之6 小时前
AI 编程开发思维
前端·后端·ai编程
踩着两条虫6 小时前
VTJ:快速开始
前端·低代码·架构
木斯佳7 小时前
前端八股文面经大全:携程前端一面(2026-04-17)·面经深度解析
前端·状态模式