博客
关于我
video-js 库使用 自定义组件
阅读量:550 次
发布时间:2019-03-08

本文共 1768 字,大约阅读时间需要 5 分钟。

Video.js 库的使用与自定义组件

引言

本文将介绍 Video.js 库的使用方法,特别关注其自定义组件的实现。通过多个案例和实践经验,分享配置和封装组件的技巧,助力开发者更好地使用该播放器。


Video.js 库概述

Video.js 是一个功能强大的视频播放器库,支持 HLS 直播流(m3u8格式)以及自定义组件开发,广泛应用于视频播放场景。此外,其对布局和控制Bar的配置选项较为丰富,能够满足多种个性化需求。


配置指南

常用配置

  • 插件支持:需要在 Vue 项目中 安装并配置相关插件,确保播放器正常运行。 请参考文档或相关博客获取具体配置项。
const playerOptions = {  controlBar: {    // 各项配置选项,可参考controlBar文档    progressControl: true,    playToggle: true,    volumePanel: true,    // 其他配置,可根据需求设置  }};
  • 普通使用方法:在 HTML 文件中添加视频元素,并通过 JavaScript 调用 Video.js 初始化玩家。
// player是视频容器的IDvar player = videojs('player', {  autoplay: 'muted',  // 其他配置选项});

控件Bar 配置

controlBar 是播放器的一大特点,提供多种常用功能按钮。默认配置中的各个控制项及其含义如下:

  • playToggle:播放/暂停按钮
  • volumePanel:音量控制面板
  • currentTimeDisplay:当前播放时间显示
  • durationDisplay:视频总时长显示

自定义控件顺序

如果需要自定义控件显示顺序,可以通过设置 children 属性来实现。例如,想将进度条放在最前面:

var controlBar = {  children: [    { name: 'progressControl' },    { name: 'playToggle' },    // 其他自定义控件  ]};

注册并使用自定义控件

想实现更深层次的个性化,可以开发自己的控制组件。如下创建一个自定义图片点击组件:

var myPlayer = videojs('player', {  controlBar: { children: [] }}, function() {  varontrolComponent = videojs.getComponent('progressControl');  videojs.registerComponent('myComponent', {    constructor: function(player, options) {      player.apply(this, arguments);      this.on('click', this.clickIcon);    },    createEl: function() {      return videojs.dom.createEl('div', {        className: 'vjs-my-components',        innerHTML: ''      });    },    clickIcon: function() {      alert('图片点击事件触发');    }  });  myPlayer.getChild('controlBar').addChild('myComponent');});

Vue 组件适配

在 Vue 项目中使用 Video.js 的封装组件,常见的做法是通过前置脚本加载相关库文件,并在 Vue 实例中注册组件。例如,可通过 node_modules/vue-video-player 目录下的源码进行参考和定制。


总结

Video.js 库提供了丰富的配置选项和灵活的扩展能力,适合适应多种视频播放场景。通过合理配置和自定义组件开发,可以显著提升播放器的用户体验。使用过程中,如遇到常见问题,可参考官方文档或相关技术博客,并灵活调整配置设置。

转载地址:http://wmuiz.baihongyu.com/

你可能感兴趣的文章
ng 指令的自定义、使用
查看>>
Nginx
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
nginx + etcd 动态负载均衡实践(四)—— 基于confd实现
查看>>
Nginx + Spring Boot 实现负载均衡
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx - Header详解
查看>>
Nginx Location配置总结
查看>>
Nginx Lua install
查看>>
Nginx upstream性能优化
查看>>
Nginx 中解决跨域问题
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理 MinIO 及 ruoyi-vue-pro 配置 MinIO 详解
查看>>
nginx 反向代理 转发请求时,有时好有时没反应,产生原因及解决
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>
nginx 后端获取真实ip
查看>>
Nginx 学习总结(16)—— 动静分离、压缩、缓存、黑白名单、性能等内容温习
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>
Nginx 常用配置清单
查看>>