Vue 中使用flv.js視頻播放器,并將其組件化

  1. 首先下載flv.js
npm install flv.js
  1. 創(chuàng)建一個(gè)頁(yè)面乒疏,用來(lái)組件化:assembly-flv.vue
<template>
  <div class="video" :style="{ height: voidHeight }">
    <video ref="videoElement" muted></video>
    <div class="img_error" v-if="imgError">
      <img src="../assets/image/wushipin_lan_da.png" alt="" />
      <p>視頻播放錯(cuò)誤蓖议,請(qǐng)聯(lián)系管理員!</p>
    </div>
  </div>
</template>

<script>
import flvjs from "flv.js";
// import wushipin_lan_da from '../assets/image/wushipin_lan_da.png';
export default {
  name: "assemblyFlv",
  props: ["url", "height", "destroy"], // 視頻流路徑蛮艰,播放器高度腋腮,是否銷毀播放器
  data() {
    return {
      flvPlayer: "",
      imgError: false,
      voidHeight: "",
    };
  },
  mounted() {
    // 判斷是否傳入高度,如果沒有,高度100%
    this.height ? (this.voidHeight = this.height) : (this.voidHeight = "100%");
    // 頁(yè)面加載完成后即寡,初始化
    this.$nextTick(() => {
      this.init(this.url);
    });
  },
  methods: {
    // 初始化
    init(source) {
      if (flvjs.isSupported()) {
        this.flvPlayer = flvjs.createPlayer(
          {
            type: "flv",
            url: source,
          },
          {
            enableWorker: false, //不啟用分離線程
            enableStashBuffer: false, //關(guān)閉IO隱藏緩沖區(qū)
            reuseRedirectedURL: true, //重用301/302重定向url徊哑,用于隨后的請(qǐng)求,如查找聪富、重新連接等莺丑。
            autoCleanupSourceBuffer: true, //自動(dòng)清除緩存
          }
        );

        this.flvPlayer.attachMediaElement(this.$refs.videoElement);
        this.flvPlayer.load();
        this.flvPlayer.play();

        // 加載完成
        this.flvPlayer.on(flvjs.Events.LOADING_COMPLETE, () => {
          this.imgError = false;
        });

        // 加載失敗
        this.flvPlayer.on(
          flvjs.Events.ERROR,
          () => {
            this.imgError = true;
          },
          (error) => {
            console.log(error);
          }
        );
      } else {
        this.imgError = true;
      }
    },
    // 銷毀
    detachMediaElement() {
      this.flvPlayer.pause();
      this.flvPlayer.unload();
      this.flvPlayer.detachMediaElement();
      this.flvPlayer.destroy();
      this.flvPlayer = "";
    },
  },
  watch: {
    url() {
      this.imgError = false;
      // 切換流之前,判斷之前的流是否銷毀
      this.flvPlayer == "" ? "" : this.detachMediaElement();
      // 初始化
      this.init(this.url);
    },
    destroy() {
      // 傳入開關(guān)值
      if (this.destroy) {
        this.init(this.url);
      } else {
        this.flvPlayer == "" ? "" : this.detachMediaElement();
      }
    },
  },
  beforeDestroy() {
    this.detachMediaElement();
  },
};
</script>

<style scoped>
.video {
  position: relative;
  height: 100%;
}
video {
  width: 100%;
  height: 100%;
  object-fit: fill;
}
.img_error {
  position: absolute;
  top: 30%;
  left: 50%;
  margin-left: -120px;
  text-align: center;
}
.img_error > img {
  margin-bottom: 1em;
}
.img_error > p {
  color: #00fdff;
  font-weight: bold;
  font-size: 1.2em;
}
</style>
  1. 在需要的頁(yè)面引入
<template>
  <div>
      <assembly-flv height="240px" :url="url" ></assembly-flv>
  </div>
</template>

<script>
import assemblyFlv from "assembly-flv.vue";
export default {
  components: { "assembly-flv": assemblyFlv },
  data() {
     return {
         url: '視頻流'
     }
  }
}
</script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末墩蔓,一起剝皮案震驚了整個(gè)濱河市梢莽,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌钢拧,老刑警劉巖蟹漓,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異源内,居然都是意外死亡葡粒,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門膜钓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)嗽交,“玉大人,你說我怎么就攤上這事颂斜》虮冢” “怎么了?”我有些...
    開封第一講書人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵沃疮,是天一觀的道長(zhǎng)盒让。 經(jīng)常有香客問我,道長(zhǎng)司蔬,這世上最難降的妖魔是什么邑茄? 我笑而不...
    開封第一講書人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮俊啼,結(jié)果婚禮上肺缕,老公的妹妹穿的比我還像新娘。我一直安慰自己授帕,他們只是感情好同木,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著跛十,像睡著了一般彤路。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上芥映,一...
    開封第一講書人閱讀 52,457評(píng)論 1 311
  • 那天洲尊,我揣著相機(jī)與錄音缝裤,去河邊找鬼。 笑死颊郎,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的霎苗。 我是一名探鬼主播姆吭,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼唁盏!你這毒婦竟也來(lái)了内狸?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤厘擂,失蹤者是張志新(化名)和其女友劉穎昆淡,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體刽严,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡昂灵,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了舞萄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片眨补。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖倒脓,靈堂內(nèi)的尸體忽然破棺而出撑螺,到底是詐尸還是另有隱情崎弃,我是刑警寧澤甘晤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布饲做,位于F島的核電站线婚,受9級(jí)特大地震影響艇炎,放射性物質(zhì)發(fā)生泄漏酌伊。R本人自食惡果不足惜缀踪,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望驴娃。 院中可真熱鬧,春花似錦唇敞、人聲如沸蔗草。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)镶柱。三九已至模叙,卻和暖如春歇拆,著一層夾襖步出監(jiān)牢的瞬間范咨,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工渠啊, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人替蛉。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像躲查,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子熙含,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容