VUE-整合视频播放(Vue-video-player组件)

转自:http://www.cppcns.com/wangluo/javascript/269655.html

下载vue-video-player

  1. npm install vue-video-player --save

在main.js文件引入

  1. import VideoPlayer from 'vue-video-player'
  2. require('video.js/dist/video-js.css')
  3. require('vue-video-player/src/custom-theme.css')
  4. Vue.use(VideoPlayer)

在页面中引入

  1. <video-player
  2. ref="videoPlayer"
  3. class="video-player vjs-custom-skin"
  4. :playsinline="true"
  5. :options="playerOptions"
  6. @play="onPlayerPlay($event)"//监听开始状态
  7. @pause="onPlayerPause($event)"//监听暂停状态
  8. />

在页面中data中配置

  1. playerOptions: {
  2. // playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度
  3. autoplay: false, // 如果true,浏览器准备好时开始回放。
  4. muted: false, // 默认情况下将会消除任何音频。
  5. loop: false, // 导致视频一结束就重新开始。
  6. preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
  7. language: 'zh-CN',
  8. aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
  9. fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
  10. sources: [
  11. {
  12. type: 'video/mp4', // 这里的种类支持很多种:基本视频格式、直播、流媒体等,具体可以参看git网址项目
  13. src: 'https://cdn.theguardian.tv/webM/2015/07/20/150716YesMen_synd_768k_vp8.webm' // url地址
  14. }
  15. ],
  16. hls: true,
  17. poster: 'http://pic33.nipic.com/20131007/13639685_123501617185_2.jpg', // 你的封面地址
  18. width: document.documentElement.clientWidth, // 播放器宽度
  19. notSupportedMessage: '此视频暂无法播放,请稍后再试', // 允许覆盖Video.js无法播放媒体源时显示的默认信息。
  20. controlBar: {
  21. timeDivider: true,
  22. durationDisplay: true,
  23. remainingTimeDisplay: false,
  24. fullscreenToggle: true // 全屏按钮
  25. }
  26. },

挂载视频组件(非必须)不写这一步也可以实现播放,添加这个是为了自定义按钮使用

  1. computed: {
  2. player() {
  3. return this.$refs.videoPlayer.player//自定义播放
  4. }
  5. },

官方文档

video.js:https://docs.videojs.com/docs/api/player.html
vue-video-player:https://github.com/surmon-china/vue-video-player

不需要兼容m3u8的,以上就可以实现能播放

兼容m3u8的需要下载

 
  1. npm install --save videojs-contrib-hls

在文件中引入

  1. import ‘videojs-contrib-hls'

我这么引入会出现找不到文件,我没找到问题所在,如果这么引入不行,可以改为

在main.js文件中

  1. const hls = require('videojs-contrib-hls')
  2. Vue.use(hls)

这样就好了

在页面中测试

  1. {
  2. type: 'application/x-mpegURL', // 这里的种类支持很多种:基本视频格式、直播、流媒体等,具体可以参看git网址项目
  3. src:
  4. 'https://cdn.letv-cdn.com/2018/12/05/JOCeEEUuoteFrjCg/playlist.m3u8' // url地址,从别的博主那看来的地址,亲测可用
  5. }

至此就可以播放了

安利一门Java超级好课!
扫码下单输优惠码【csdnfxzs】再减5元,比官网还便宜!

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值