videojs使用技巧

1 初始化

Video.js初始化有两种方式。javascript

1.1 标签方式

一种是在<video>标签里面加上class="video-js"data-setup='{}'属性。css

注意,二者缺一不可。html

刚开始的时候我以为后面的值为空对象{},不放也行,java

致使播放器加载不出来,后来加上来就能够了。web

1.2 JS方式

另一种初始化 video.js 的方法是经过JS,格式:apache

var player = videojs('my-player');

这样有个要求,就是不能配置data-setup,而且须要传入<video>idide

固然,若是不想一个个初始化,能够这样:post

(function(){ var videos = document.getElementsByTagName('video'); for(i=0; i<videos.length; i++) { var video = videos[i]; if(video.className.indexOf('video-js') > -1) { videojs(video.id).ready(function(){ }); } } })();

2 播放按钮居中

video.js默认的播放按钮在左上角,应该是 video.js 开发人员认为放中间会遮挡内容,因此没放中间。ui

不过咱们常见的通常都在中间,比较符合习惯。spa

这是能够经过参数修改的,在<video>标签中加入vjs-big-play-centered类,就能够了。

像这样:

class="video-js vjs-big-play-centered"

3 支持<audio>音乐标签

video.js 4.9开始支持<audio>标签,与video不一样的是:播放audio时封面不会消失。

可是上面的播放框仍是一直在的,配置方式和<video>标签同样,也必需要配置data-setup参数。

4 禁止在iPhone safari中自动全屏

方法以下,在<video>标签中加入playsinline参数,

<video playsinline ></video>

注意,在iOS10以前用的是webkit-playsinline

5 暂停时显示播放按钮

video.js 在未播放时,会显示一个大的播放按钮,上面咱们提到如何让他居中。

那么,如何在视频暂停时也显示这个播放按钮呢?

有不少用JS的解决办法,感受都挺麻烦的。

其实用CSS就能够搞定了:

.vjs-paused .vjs-big-play-button, .vjs-paused.vjs-has-started .vjs-big-play-button { display: block; }

是否是很轻便很简单 :)

6 播放按钮变○圆形

video.js 默认的播放按钮是圆角矩形,

咱们通常更熟悉播放按钮为圆形的:

那么怎么改呢?仍是用CSS来解决。

.video-js .vjs-big-play-button{ font-size: 2.5em; line-height: 2.3em; height: 2.5em; width: 2.5em; -webkit-border-radius: 2.5em; -moz-border-radius: 2.5em; border-radius: 2.5em; background-color: #73859f; background-color: rgba(115,133,159,.5); border-width: 0.15em; margin-top: -1.25em; margin-left: -1.75em; } /* 中间的播放箭头 */ .vjs-big-play-button .vjs-icon-placeholder { font-size: 1.63em; } /* 加载圆圈 */ .vjs-loading-spinner { font-size: 2.5em; width: 2em; height: 2em; border-radius: 1em; margin-top: -1em; margin-left: -1.5em; }

由于原来居中的时候宽度和高度改变了,因此margin的值也要相应改变

7 点击屏幕播放/暂停

这个是视频播放的时候用得较多的功能,解决方法以下。

.video-js.vjs-playing .vjs-tech { pointer-events: auto; }

pointer-events是CSS的一个属性,用来控制鼠标的动做,具体可参考《CSS里的pointer-events属性》。

8 重载视频文件

总有那么一些情形,咱们须要 video.js 从新载入视频文件。

好比,当即播放刚上传的文件。

例如这样的标签:

<video id="example_video">     <source id="videoMP4" src="1.mp4" /> </video> <button id="reload">重载</button>

在video.js中,用现成的js方法就能够实现:

var video = document.getElementById('example_video'); var source = document.getElementById('videoMP4'); $("#reload").click(function() { video.pause() source.setAttribute('src', '2.mp4'); video.load(); video.play(); });

或者:

var video = document.getElementById('example_video'); $("#reload").click(function() { video.pause() video.setAttribute('src', '2.mp4'); video.load(); video.play(); });

9 进度显示当前播放时间

video.js 默认倒序显示时间,也就是视频播放的剩余时间。

要显示当前的播放时间,以及总共视频时长,加2行CSS解决:

.video-js .vjs-time-control{display:block;} .video-js .vjs-remaining-time{display: none;}
相关文章
相关标签/搜索