vue使用video.js實(shí)現(xiàn)播放m3u8格式的視頻
一、前言
實(shí)時(shí)推送的視頻流的需求,vue
中就可以使用video.js
播放m3u8
格式的視頻流
1.官網(wǎng)
2.Github
二、實(shí)現(xiàn)
2.1、安裝依賴(lài)
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
引入如下依賴(lài):
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流的話(huà),需再安裝依賴(lài)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的寫(xiě)法小結(jié)
這篇文章主要介紹了vue 動(dòng)態(tài)樣式綁定 class/style的寫(xiě)法小結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03Element?plus中el-input框回車(chē)觸發(fā)頁(yè)面刷新問(wèn)題以及解決辦法
在el-form表單組件中el-input組件輸入內(nèi)容后按下Enter鍵刷新了整個(gè)頁(yè)面,下面這篇文章主要給大家介紹了關(guān)于Element?plus中el-input框回車(chē)觸發(fā)頁(yè)面刷新問(wèn)題以及解決辦法,需要的朋友可以參考下2024-03-03vue實(shí)現(xiàn)驗(yàn)證碼按鈕倒計(jì)時(shí)功能
最近項(xiàng)目結(jié)束,空閑時(shí)間比較多,今天小編抽時(shí)間給大家使用vue寫(xiě)一個(gè)小例子,就決定做驗(yàn)證碼倒計(jì)時(shí)功能,具體實(shí)例代碼大家參考下本文2018-04-04vue3數(shù)據(jù)更新而視圖未更新問(wèn)題解決
本文主要介紹了vue3?解決數(shù)據(jù)更新而視圖未更新問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-10-10Vue3實(shí)現(xiàn)組件級(jí)基類(lèi)的多種方法
vue3提供了 mixins和extends,但是嘗試之后發(fā)現(xiàn)這兩種方法只支持純OptionAPI,設(shè)置的data會(huì)被識(shí)別,但是設(shè)置的setup里return 的 reactive,完全無(wú)效,setup也沒(méi)有被執(zhí)行,這篇文章主要介紹了Vue3實(shí)現(xiàn)組件級(jí)基類(lèi)的幾種方法,需要的朋友可以參考下2023-04-04用Vue.extend構(gòu)建消息提示組件的方法實(shí)例
本篇文章主要介紹了用Vue.extend構(gòu)建消息提示組件的方法實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08vue2和vue3中provide/inject的基本用法示例
Vue中的provide/inject是一種組件間通信的方式,它允許父組件向子組件傳遞數(shù)據(jù),而不需要通過(guò)props或事件來(lái)實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue2/vue3中provide/inject的基本用法的相關(guān)資料,需要的朋友可以參考下2023-04-04