欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項目中使用hls.js播放m3u8視頻踩過的坑小結

 更新時間:2025年07月23日 09:36:13   作者:LIU雷  
hls.js是一個用于在瀏覽器中播放HLS(HTTP?Live?Streaming)視頻流的JavaScript庫,這篇文章主要介紹了vue項目中使用hls.js播放m3u8視頻踩過坑的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下

video.js 是一個功能強大的 HTML5 視頻播放器,結合 videojs-contrib-hls 插件可以輕松實現(xiàn) .m3u8 格式視頻的播放。

下面展示一些 代碼片。

安裝依賴

npm install video.js videojs-contrib-hls

一、vue項目中代碼片段 ,作為組件使用  

<!-- 視頻 -->
<template>
  <div class="video-box">
    <!-- 視頻播放器 -->
    <video id="video" controls autoplay width="100%" height="100%"></video>
  </div>
</template>

<script>
import Hls from "hls.js";
import popWrapper from "@/components/popWrapper";

export default {
  name: "videoPop",
  data() {
    return {
    };
  },
  created() {},
  mounted() {
    // 攝像頭視頻彈窗傳值
    this.bus.$on("videoOpen", (row) => {
      this.showWtck(row);
    });
  },
  methods: {
    videoClose() {
      this.showOceanVideo = false;
    },
    // 攝像頭視頻彈窗傳值 sxtbh
    async showWtck() {
     this.videoPlay();
      this.showOceanVideo = true;
    },
    videoPlay(index) {
      // 獲取 video 元素
      const video = document.getElementById("video");
      // HLS 流地址
      const videoSrc = 'https://bitdash-a.akamaihd.net/content/sintel/hls/playlist.m3u8';//測試開源地址 注:視頻格式需要時164的,web端此方法不支持165
      // 檢查是否支持 HLS.js
      if (Hls.isSupported()) {
        // 創(chuàng)建 HLS 實例
        const hls = new Hls();

        // 加載 .m3u8 文件
        hls.loadSource(videoSrc);

        // 將 HLS 實例綁定到 video 元素
        hls.attachMedia(video);

        // 監(jiān)聽事件:當 HLS 清單文件解析完成后自動播放
        hls.on(Hls.Events.MANIFEST_PARSED, () => {
          console.log("HLS stream loaded successfully");
          video.play();
        });

        // 監(jiān)聽錯誤事件
        hls.on(Hls.Events.ERROR, (event, data) => {
          this.videoPlay()
          console.error("HLS error:", data);
        });
      } else if (video.canPlayType("application/vnd.apple.mpegurl")) {
        // 如果瀏覽器原生支持 HLS(如 Safari)
        video.src = videoSrc;
        video.addEventListener("loadedmetadata", () => {
          console.log("Native HLS playback supported");
          video.play();
        });
      } else {
        alert('您的瀏覽器不支持播放此視頻。')
        console.error("Your browser does not support HLS playback.");
      }
    },
  },
  beforeDestroy() {
  },
};
</script>

<style lang='scss' scoped>
.video-box {
  height: 700px;
  margin-bottom: 30px;
  overflow: auto;
}
</style>

二、以下是H5的Demo可以直接運行

直接復制代碼,驗證一下提供方的視頻地址是否有誤

此處踩過坑 265格式web端不能播放,資源格式264可以正常播放

測試監(jiān)控地址是否可以正常播放 我使用的是工具 VLC media player,我是圖方便在電腦管家下載的

(H265)

h264

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>HLS.js 播放監(jiān)控視頻</title>
  <!-- 引入 hls.js -->
  <script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script>
  <style>
    body {
      font-family: Arial, sans-serif;
      margin: 0;
      padding: 0;
      display: flex;
      justify-content: center;
      align-items: center;
      height: 100vh;
      background-color: #f4f4f4;
    }
    video {
      max-width: 100%;
      max-height: 100%;
      border: 1px solid #ccc;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    }
  </style>
</head>
<body>
  <div>
    <h1 style="text-align: center;">HLS.js 播放監(jiān)控視頻</h1>
    <!-- 視頻播放器 -->
    <video id="video" controls autoplay width="640" height="360"></video>
  </div>

  <script>
    // 獲取 video 元素
    const video = document.getElementById('video');

    // HLS 流地址
    // const videoSrc = 'https://bitdash-a.akamaihd.net/content/sintel/hls/playlist.m3u8';//測試開源地址
    // const videoSrc = 'http://cmgw-vpc.lechange.com:8888/LCO/9C07128PAG4B9E2/0/1/20250324T021313/openhz0735a494162c4ba6bb287d7b6a5f4bb7.m3u8?source=open';//大華提供地址165
    const videoSrc = 'http://cmgw-vpc.lechange.com:8888/LCO/9C07128PAGC1657/0/0/20250324T015744/openhz136dd7fbc6484a5095579ba383b035bb.m3u8?source=open';//大華提供地址164

    // 檢查是否支持 HLS.js
    if (Hls.isSupported()) {
      // 創(chuàng)建 HLS 實例
      const hls = new Hls();

      // 加載 .m3u8 文件
      hls.loadSource(videoSrc);

      // 將 HLS 實例綁定到 video 元素
      hls.attachMedia(video);

      // 監(jiān)聽事件:當 HLS 清單文件解析完成后自動播放
      hls.on(Hls.Events.MANIFEST_PARSED, () => {
        console.log('HLS stream loaded successfully');
        video.play();
      });

      // 監(jiān)聽錯誤事件
      hls.on(Hls.Events.ERROR, (event, data) => {
        console.error('HLS error:', data);
      });
    } else if (video.canPlayType('application/vnd.apple.mpegurl')) {
      // 如果瀏覽器原生支持 HLS(如 Safari)
      video.src = videoSrc;
      video.addEventListener('loadedmetadata', () => {
        console.log('Native HLS playback supported');
        video.play();
      });
    } else {
      console.error('Your browser does not support HLS playback.');
    }
  </script>
</body>
</html>

總結 

到此這篇關于vue項目中使用hls.js播放m3u8視頻踩過坑的文章就介紹到這了,更多相關vue hls.js播放m3u8視頻內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue.js+Echarts開發(fā)圖表放大縮小功能實例

    vue.js+Echarts開發(fā)圖表放大縮小功能實例

    本篇文章主要介紹了vue.js+Echarts開發(fā)圖表放大縮小功能實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • vue3 中使用vue?img?cutter?圖片裁剪插件的方法

    vue3 中使用vue?img?cutter?圖片裁剪插件的方法

    這篇文章主要介紹了vue3 中使用vue?img?cutter?圖片裁剪插件的方法,首先安裝依賴,構建 components/ImgCutter.vue 組件,需要的朋友可以參考下
    2024-05-05
  • Element-UI清空表單及驗證不生效的問題解決

    Element-UI清空表單及驗證不生效的問題解決

    本文主要介紹了Element-UI清空表單及驗證不生效的問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-08-08
  • vue中遇到的坑之變化檢測問題(數(shù)組相關)

    vue中遇到的坑之變化檢測問題(數(shù)組相關)

    這篇文章主要介紹了vue中遇到的坑之變化檢測問題(數(shù)組相關) ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • 詳解element-ui日期時間選擇器的日期格式化問題

    詳解element-ui日期時間選擇器的日期格式化問題

    這篇文章主要介紹了詳解element-ui日期時間選擇器的日期格式化問題,本文用到了DateTimePicker來選擇日期時間,但是在將數(shù)據(jù)傳回后臺的過程中遇到了一些令人頭疼的問題,有興趣的一起來了解一下
    2019-04-04
  • 解決Vue在Tomcat8下部署頁面不加載的問題

    解決Vue在Tomcat8下部署頁面不加載的問題

    今天小編就為大家分享一篇解決Vue在Tomcat8下部署頁面不加載的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 基于 Vue 的樹形選擇組件的示例代碼

    基于 Vue 的樹形選擇組件的示例代碼

    本篇文章主要介紹了基于 Vue 的樹形選擇組件的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • Vue3使用TypeIt實現(xiàn)文字打字機效果的代碼示例

    Vue3使用TypeIt實現(xiàn)文字打字機效果的代碼示例

    在現(xiàn)代網(wǎng)頁設計中,文字打字機效果是一種非常流行的動畫效果,能夠吸引用戶的注意力并提升用戶體驗,本文將介紹如何在 Vue 3 中使用 TypeIt 庫實現(xiàn)文字打字機效果,并分享一些實用的技巧和示例,需要的朋友可以參考下
    2025-01-01
  • vue如何使用vant組件的field組件disabled修改默認樣式

    vue如何使用vant組件的field組件disabled修改默認樣式

    這篇文章主要介紹了vue如何使用vant組件的field組件disabled修改默認樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue前端vue.config.js簡介

    Vue前端vue.config.js簡介

    vue.config.js?是一個可選的配置文件,如果項目的?(和?package.json?同級的)?根目錄中存在這個文件,那么它會被?@vue/cli-service?自動加載,本文重點介紹VUE前端vue.config.js簡介,感興趣的朋友跟隨小編一起看看吧
    2023-01-01

最新評論