vue使用video.js實(shí)現(xiàn)播放m3u8格式的視頻
一、前言
實(shí)時(shí)推送的視頻流的需求,vue中就可以使用video.js播放m3u8格式的視頻流
1.官網(wǎng)

2.Github

二、實(shí)現(xiàn)
2.1、安裝依賴
yarn add video.js yarn add videojs-contrib-hls // 這是播放hls流需要的插件 yarn add videojs-flash // 這是播放rtmp流需要的插件 yarn add mux.js // 在vue項(xiàng)目中,若不安裝它可能報(bào)錯(cuò)
2.2、main.js
引入如下依賴:
import "video.js/dist/video-js.css"; // 引入video.js的css import hls from "videojs-contrib-hls"; // 播放hls流需要的插件 import Vue from "vue"; Vue.use(hls);
2.3、video.vue
抽離出來(lái)一個(gè)視頻組件
<template>
<video id="videoPlayer" class="video" muted width="100%" height="580px" />
</template>
<script>
import Videojs from 'video.js'
export default {
data() {
return {
player: null
}
},
beforeDestroy() {
if (this.player) {
this.player.dispose() // Removing Players,該方法會(huì)重置videojs的內(nèi)部狀態(tài)并移除dom
}
},
activated() {
if (this.player) {
this.player.play()
}
},
deactivated() {
if (this.player) {
this.player.pause()
}
},
mounted() {
this.initVideo()
},
methods: {
initVideo(url) {
if (!this.player) {
this.player = Videojs('videoPlayer', {
autoplay: true, // 設(shè)置自動(dòng)播放
muted: true, // 設(shè)置了它為true,才可實(shí)現(xiàn)自動(dòng)播放,同時(shí)視頻也被靜音 (Chrome66及以上版本,禁止音視頻的自動(dòng)播放)
preload: 'auto', // 預(yù)加載
controls: false // 顯示播放的控件
})
}
this.player.src([{
src: url,
type: 'application/x-mpegURL' // 告訴videojs,這是一個(gè)hls流
}])
}
}
}
</script>
<style lang="scss" scoped>
.video, video {
width: 100%;
height: 580px;
}
/deep/ .vjs-loading-spinner {
position: relative;
.vjs-control-text {
opacity: 0;
}
}
</style>
2.4、其它
rtmp流的話,需再安裝依賴videojs-flash
// main.js import flash from "videojs-flash"; // 播放rtmp流需要的插件 import Vue from "vue"; Vue.use(flash);
組件中設(shè)置src時(shí)需要注意:
this.player.src([{
src: url,
type: 'rtmp/flv' // 告訴videojs這是一個(gè)rtmp流視頻
}])
到此這篇關(guān)于vue使用video.js實(shí)現(xiàn)播放m3u8格式的視頻的文章就介紹到這了,更多相關(guān)vue video.js播放m3u8視頻內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 動(dòng)態(tài)樣式綁定 class/style的寫法小結(jié)
這篇文章主要介紹了vue 動(dòng)態(tài)樣式綁定 class/style的寫法小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03
Element?plus中el-input框回車觸發(fā)頁(yè)面刷新問題以及解決辦法
在el-form表單組件中el-input組件輸入內(nèi)容后按下Enter鍵刷新了整個(gè)頁(yè)面,下面這篇文章主要給大家介紹了關(guān)于Element?plus中el-input框回車觸發(fā)頁(yè)面刷新問題以及解決辦法,需要的朋友可以參考下2024-03-03
vue實(shí)現(xiàn)驗(yàn)證碼按鈕倒計(jì)時(shí)功能
最近項(xiàng)目結(jié)束,空閑時(shí)間比較多,今天小編抽時(shí)間給大家使用vue寫一個(gè)小例子,就決定做驗(yàn)證碼倒計(jì)時(shí)功能,具體實(shí)例代碼大家參考下本文2018-04-04
Vue3實(shí)現(xiàn)組件級(jí)基類的多種方法
vue3提供了 mixins和extends,但是嘗試之后發(fā)現(xiàn)這兩種方法只支持純OptionAPI,設(shè)置的data會(huì)被識(shí)別,但是設(shè)置的setup里return 的 reactive,完全無(wú)效,setup也沒有被執(zhí)行,這篇文章主要介紹了Vue3實(shí)現(xiàn)組件級(jí)基類的幾種方法,需要的朋友可以參考下2023-04-04
用Vue.extend構(gòu)建消息提示組件的方法實(shí)例
本篇文章主要介紹了用Vue.extend構(gòu)建消息提示組件的方法實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
vue2和vue3中provide/inject的基本用法示例
Vue中的provide/inject是一種組件間通信的方式,它允許父組件向子組件傳遞數(shù)據(jù),而不需要通過props或事件來(lái)實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue2/vue3中provide/inject的基本用法的相關(guān)資料,需要的朋友可以參考下2023-04-04

