vue-video-player基本使用

項目上有一個新的需求,點擊視頻全屏播放,當即想到了video.js插件,兼容性好,比原生video好用多了。因爲項目用的是vue-element-ui技術棧,考慮技術的融合性,最終使用了vue-video-player

  1. 首先是npm i vue-video-player -D 安裝依賴
  2. 在main.js裏面引入
import VideoPlayer from 'vue-video-player'
require('video.js/dist/video-js.css')
require('vue-video-player/src/custom-theme.css')
Vue.use(VideoPlayer)

此處代碼主要是用來覆蓋video的播放按鈕樣式
require('./styles/video.css');具體內容如下

 .video-js .vjs-big-play-button {
	  width: 72px;
	  height: 72px;
	  border-radius: 100%;
	  z-index: 100;
	  background-color: #ffffff;
	  border: solid 1px #979797;
	}
  1. vue組件中使用
<template>
 <div class="player">
   <video-player class="video-player vjs-custom-skin"
                 ref="videoPlayer"
                 :playsinline="true"
                 style="object-fit:fill"
                 :options="playerOptions"
                 :x5-video-player-fullscreen="true"
                 @pause="onPlayerPause($event)"
                 @play="onPlayerPlay($event)"
                 @fullscreenchange="onFullscreenChange($event)"
                 @click="fullScreen"
   >
   </video-player>
 </div>
</template>
<script>
  import test from '@/assets/workDetail/test.png'
  import {videoPlayer} from 'vue-video-player';

  export default {
    components: {
      videoPlayer
    },
    data() {
      return {
        pictureImg: test,
        playerOptions: {
//        playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
          autoplay: false, //如果true,瀏覽器準備好時開始回放。
          muted: false, // 默認情況下將會消除任何音頻。
          loop: false, // 導致視頻一結束就重新開始。
          preload: 'auto', // 建議瀏覽器在<video>加載元素後是否應該開始下載視頻數據。auto瀏覽器選擇最佳行爲,立即開始加載視頻(如果瀏覽器支持)
          language: 'zh-CN',
          aspectRatio: '16:9', // 將播放器置於流暢模式,並在計算播放器的動態大小時使用該值。值應該代表一個比例 - 用冒號分隔的兩個數字(例如"16:9"或"4:3")
          fluid: true, // 當true時,Video.js player將擁有流體大小。換句話說,它將按比例縮放以適應其容器。
          sources: [{
            type: "video/mp4",
            src: "你的視頻地址"
          }],
          poster: "你的封面地址",
          width: document.documentElement.clientWidth,
          notSupportedMessage: '此視頻暫無法播放,請稍後再試', //允許覆蓋Video.js無法播放媒體源時顯示的默認信息。
          controlBar: {
            // timeDivider: true,
            // durationDisplay: true,
            // remainingTimeDisplay: false,
            fullscreenToggle: true  //全屏按鈕
          }
        }
      }
    },
    methods: {
      fullScreen() {
        const player = this.$refs.videoPlayer.player
        player.requestFullscreen()//調用全屏api方法
        player.isFullscreen(true)
        player.play()
      },
      onPlayerPlay(player) {
        player.play()
      },
      onPlayerPause(player) {
        // alert("pause");
      }
    },
    computed: {
      player() {
        return this.$refs.videoPlayer.player
      }
    }
  }

</script>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章