vue使用video.js實(shí)現(xiàn)播放m3u8格式的視頻
一、前言
實(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項目中,若不安裝它可能報錯
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
抽離出來一個視頻組件
<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,該方法會重置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è)置自動播放 muted: true, // 設(shè)置了它為true,才可實(shí)現(xiàn)自動播放,同時視頻也被靜音 (Chrome66及以上版本,禁止音視頻的自動播放) preload: 'auto', // 預(yù)加載 controls: false // 顯示播放的控件 }) } this.player.src([{ src: url, type: 'application/x-mpegURL' // 告訴videojs,這是一個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時需要注意:
this.player.src([{ src: url, type: 'rtmp/flv' // 告訴videojs這是一個rtmp流視頻 }])
到此這篇關(guān)于vue使用video.js實(shí)現(xiàn)播放m3u8格式的視頻的文章就介紹到這了,更多相關(guān)vue video.js播放m3u8視頻內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 動態(tài)樣式綁定 class/style的寫法小結(jié)
這篇文章主要介紹了vue 動態(tài)樣式綁定 class/style的寫法小結(jié),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03Element?plus中el-input框回車觸發(fā)頁面刷新問題以及解決辦法
在el-form表單組件中el-input組件輸入內(nèi)容后按下Enter鍵刷新了整個頁面,下面這篇文章主要給大家介紹了關(guān)于Element?plus中el-input框回車觸發(fā)頁面刷新問題以及解決辦法,需要的朋友可以參考下2024-03-03用Vue.extend構(gòu)建消息提示組件的方法實(shí)例
本篇文章主要介紹了用Vue.extend構(gòu)建消息提示組件的方法實(shí)例,具有一定的參考價值,有興趣的可以了解一下2017-08-08vue2和vue3中provide/inject的基本用法示例
Vue中的provide/inject是一種組件間通信的方式,它允許父組件向子組件傳遞數(shù)據(jù),而不需要通過props或事件來實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue2/vue3中provide/inject的基本用法的相關(guān)資料,需要的朋友可以參考下2023-04-04