news 2026/4/23 14:09:26

使用Vue播放M3U8视频流的方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用Vue播放M3U8视频流的方法

使用Vue播放M3U8视频流的方法

安装依赖
需要安装video.js和videojs-contrib-hls插件,用于解析和播放M3U8格式的视频流。

npm install video.js videojs-contrib-hls

引入并初始化Video.js
在Vue组件中引入Video.js及相关样式,初始化播放器并配置HLS支持。

importvideojsfrom'video.js'import'video.js/dist/video-js.css'import'videojs-contrib-hls'exportdefault{mounted(){this.initVideoPlayer()},methods:{initVideoPlayer(){this.player=videojs(this.$refs.videoPlayer,{autoplay:true,controls:true,sources:[{src:'your-m3u8-url.m3u8',type:'application/x-mpegURL'}]})}},beforeDestroy(){if(this.player){this.player.dispose()}}}

模板部分
在模板中添加video标签作为播放器容器,需设置data-setup属性为空对象以启用Video.js初始化。

<template><div><videoref="videoPlayer"class="video-js vjs-default-skin"width="640"height="360"data-setup="{}"></video></div></template>

样式调整

.video-js{width:100%;max-width:640px;margin:0 auto;}

通过CSS调整播放器尺寸和外观,确保适应页面布局。

注意事项
确保M3U8视频流地址可跨域访问,或配置服务器CORS策略。
移动端可能需要添加playsinline属性以实现内联播放。
若使用HTTPS环境,需确保视频流地址同为HTTPS。

完整组件示例

<template><divclass="video-container"><videoref="videoPlayer"class="video-js"></video></div></template><script>importvideojsfrom'video.js'import'video.js/dist/video-js.css'import'videojs-contrib-hls'exportdefault{props:{src:{type:String,required:true}},mounted(){this.initPlayer()},methods:{initPlayer(){this.player=videojs(this.$refs.videoPlayer,{autoplay:false,controls:true,sources:[{src:this.src,type:'application/x-mpegURL'}]})}},beforeDestroy(){if(this.player){this.player.dispose()}}}</script><stylescoped>.video-container{margin:20px auto;width:80%;}</style>

替代方案(使用hls.js)
若需更轻量级方案,可使用hls.js库直接处理M3U8流。

安装hls.js

npminstallhls.js

实现代码

importHlsfrom'hls.js'exportdefault{data(){return{hls:null}},mounted(){this.loadVideo()},methods:{loadVideo(){constvideoSrc='your-m3u8-url.m3u8'constvideo=this.$refs.videoPlayerif(Hls.isSupported()){this.hls=newHls()this.hls.loadSource(videoSrc)this.hls.attachMedia(video)}elseif(video.canPlayType('application/vnd.apple.mpegurl')){video.src=videoSrc}}},beforeDestroy(){if(this.hls){this.hls.destroy()}}}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 5:00:04

轻松掌握POV-Ray:专业级光线追踪渲染入门指南

轻松掌握POV-Ray&#xff1a;专业级光线追踪渲染入门指南 【免费下载链接】povray The Persistence of Vision Raytracer: http://www.povray.org/ 项目地址: https://gitcode.com/gh_mirrors/po/povray POV-Ray&#xff08;Persistence of Vision Raytracer&#xff09…

作者头像 李华
网站建设 2026/4/23 11:34:04

MinIO对象存储搭建与S3兼容实战

本文详解MinIO对象存储的部署配置、S3兼容API使用、分布式集群搭建等实践。 前言 对象存储越来越重要&#xff1a; 海量非结构化数据存储图片、视频、备份文件云原生应用标配 MinIO是最流行的开源对象存储&#xff1a; S3 API 100%兼容高性能&#xff08;单节点可达100Gbps…

作者头像 李华
网站建设 2026/4/23 11:32:22

探索macOS开源应用的世界:从入门到精通

探索macOS开源应用的世界&#xff1a;从入门到精通 【免费下载链接】open-source-mac-os-apps serhii-londar/open-source-mac-os-apps: 是一个收集了众多开源 macOS 应用程序的仓库&#xff0c;这些应用程序涉及到各种领域&#xff0c;例如编程、生产力工具、游戏等。对于开发…

作者头像 李华
网站建设 2026/4/15 12:37:11

5分钟精通YOLOv9模型评估:从零基础到实战高手的完整指南

5分钟精通YOLOv9模型评估&#xff1a;从零基础到实战高手的完整指南 【免费下载链接】yolov9 项目地址: https://gitcode.com/GitHub_Trending/yo/yolov9 你是否曾经面对训练好的YOLOv9模型&#xff0c;却不知道如何客观评价它的真实性能&#xff1f;在目标检测项目中&…

作者头像 李华
网站建设 2026/4/21 13:26:21

基于VUE的企业客户信息管理系统[VUE]-计算机毕业设计源码+LW文档

摘要&#xff1a;在市场竞争日益激烈的当下&#xff0c;客户作为企业的核心资源&#xff0c;其信息管理的高效性与精准性对企业发展至关重要。本文阐述了一个基于VUE框架开发的企业客户信息管理系统&#xff0c;详细介绍了系统的需求分析、技术选型、架构设计、功能模块设计及实…

作者头像 李华
网站建设 2026/4/15 19:51:07

ClickShow鼠标点击特效工具使用指南

ClickShow鼠标点击特效工具使用指南 【免费下载链接】ClickShow 鼠标点击特效 项目地址: https://gitcode.com/gh_mirrors/cl/ClickShow 在屏幕录制、教学演示或远程协作过程中&#xff0c;准确展示鼠标操作轨迹和点击位置往往至关重要。ClickShow作为一款专业的鼠标点击…

作者头像 李华