博客
关于我
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/

你可能感兴趣的文章
PAT甲级——1001 A+B Format (20分)
查看>>
Skywalking原理
查看>>
PAT甲级——1006 Sign In and Sign Out (25分)
查看>>
PAT甲级——1007 Maximum Subsequence Sum (25分)
查看>>
PAT甲级——1009 Product of Polynomials (25分)(最后一个测试点段错误)
查看>>
PayPal网站付款标准版(for PHP)
查看>>
Paystack Android SDK 集成与使用指南
查看>>
pbf格式详解,javascript加载导出pbf文件示例
查看>>
PBOC2.0与3.0的区别
查看>>
PbootCMS entrance.php SQL注入漏洞复现
查看>>
PbootCMS 前台RCE漏洞复现
查看>>
PBT
查看>>
PCA---主成成分分析
查看>>
PCA降维demo
查看>>
SharePoint 2013 图文开发系列之定义站点模板
查看>>
PCI Express学习篇:Power Management(二)
查看>>
pcie握手机制_【博文连载】PCIe扫盲——Ack/Nak 机制详解(一)
查看>>
PC史上最悲剧的16次失败
查看>>
PC端恶意代码分析Lab1.1-5.1,从零基础到精通,收藏这篇就够了!
查看>>
PC端编辑 但能在PC端模拟移动端预览的富文本编辑器
查看>>