使用vue-video-player插件实现视频播放

来自于https://blog.csdn.net/abelethan/article/details/89016678博客

1下载插件==》npm install vue-video-player -s

2在main.js引入 

// 视频播放的插件
import VideoPlayer from 'vue-video-player'
import 'vue-video-player/src/custom-theme.css'
import 'video.js/dist/video-js.css'
Vue.use(VideoPlayer)
 
3在你要使用插件的页面  类demo
   <div class='demo col-md-3'>
         <h6 class="wuliutitle">|&emsp;第四期:物流网络规划框架</h6>
         <video-player class="video-player vjs-custom-skin"
                            ref="videoPlayer"
                            :playsinline="true"
                            :options="playerOptions0">
         </video-player>
    </div>

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
data(){
     return{
           playerOptions0: {
                 //播放速度
                 playbackRates: [0.5, 1.0, 1.5, 2.0],
                 //如果true,浏览器准备好时开始回放。
                 autoplay: false,
                 // 默认情况下将会消除任何音频。
                 muted: false,
                 // 导致视频一结束就重新开始。
                 loop: false,
                 // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)
                 preload: 'auto',
                 language: 'zh-CN',
                  // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")
                 aspectRatio: '16:9',
                  // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。
                 fluid: true,
                 sources: [{
                     //类型
                     type: "video/mp4",
                     //url地址
                     src: ''
                 }],
                 //你的封面地址
                 poster: '',
                  //允许覆盖Video.js无法播放媒体源时显示的默认信息。
                 notSupportedMessage: '此视频暂无法播放,请稍后再试',
                 controlBar: {
                     timeDivider: true,
                     durationDisplay: true,
                     remainingTimeDisplay: false,
                     //全屏按钮
                     fullscreenToggle: true 
                 }
           },
 
      
     }
   },

 一定要写宽高否则效果可能展示不出来,

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
.demo{
    display: inline-block;
    width: 600px;
    height: auto;
    text-align: center;
    line-height: 100px;
    border: 1px solid transparent;
    border-radius: 4px;
    overflow: hidden;
    background: #fff;
    position: relative;
    /* box-shadow: 0 1px 1px rgba(0, 0, 0, .2); */
    
  }
  
  .demo:hover{
    display: block;
  }  

 控制按钮的大小

1
2
3
.vjs-custom-skin > .video-js .vjs-big-play-button {
 transform: scale(0.6) !important;
}

  

posted @   南风晚来晚相识  阅读(5054)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示