2016-12-02 14:27:59 -05:00
# Player Workflows
2016-12-20 16:55:59 -05:00
2017-03-21 17:13:06 -04:00
This document outlines many considerations for using Video.js for advanced player workflows. Be sure to read [the setup guide ](/docs/guides/setup.md ) first!
2016-12-02 14:27:59 -05:00
2016-12-20 16:55:59 -05:00
## Table of Contents
2016-12-20 18:20:31 -05:00
* [Accessing a player that has already been created on a page ](#accessing-a-player-that-has-already-been-created-on-a-page )
2016-12-20 16:55:59 -05:00
* [Removing Players ](#removing-players )
* [dispose() ](#dispose )
2019-10-03 13:38:20 -04:00
* [Checking if a Player is Disposed ](#checking-if-a-player-is-disposed )
2016-12-20 16:55:59 -05:00
* [Signs of an Undisposed Player ](#signs-of-an-undisposed-player )
* [Showing and Hiding a Player ](#showing-and-hiding-a-player )
2016-12-20 18:20:31 -05:00
* [Changing the volume of a player ](#changing-the-volume-of-a-player )
* [Making the player fullscreen ](#making-the-player-fullscreen )
* [Using Playback information functions ](#using-playback-information-functions )
* [Dealing with the source or the poster on the player ](#dealing-with-the-source-or-the-poster-on-the-player )
2020-08-06 07:42:34 +02:00
* [Accessing the Tech on the player ](#accessing-the-tech-on-the-player )
2016-12-20 16:55:59 -05:00
* [Using Video.js with... ](#using-videojs-with )
* [jQuery ](#jquery )
* [React ](#react )
* [Ember ](#ember )
* [Angular ](#angular )
2019-03-29 12:56:29 +13:00
* [Vue ](#vue )
2016-12-20 16:55:59 -05:00
2016-12-20 18:20:31 -05:00
## Accessing a player that has already been created on a page
After an instance has been created it can be accessed globally in two ways:
1. By calling `videojs('example_video_id');`
2021-03-23 22:40:49 +01:00
1. By using it directly via `videojs.players.example_video_id;`
2016-12-20 18:20:31 -05:00
2016-12-02 14:27:59 -05:00
## Removing Players
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
No matter the term used for it, web applications are becoming common. Not everything is a static, load-once-and-done web page anymore! This means that developers need to be able to manage the full lifecycle of a video player - from creation to destruction. Video.js supports player removal through the `dispose()` method.
2018-08-10 15:13:32 -04:00
### [`dispose()`](https://docs.videojs.com/Player.html#dispose)
2016-12-20 16:55:59 -05:00
2018-08-10 15:13:32 -04:00
This method is available on all Video.js players and [components ](https://docs.videojs.com/Component.html#dispose ). It is _the only_ supported method of removing a Video.js player from both the DOM and memory. For example, the following code sets up a player and then disposes it when media playback is complete:
2016-12-02 14:27:59 -05:00
```js
var player = videojs('my-player');
player.on('ended', function() {
this.dispose();
});
```
Calling `dispose()` will have a few effects:
1. Trigger a `"dispose"` event on the player, allowing for any custom cleanup tasks that need to be run by your integration.
1. Remove all event listeners from the player.
1. Remove the player's DOM element(s).
Additionally, these actions are recursively applied to _all_ the player's child components.
> **Note**: Do _not_ remove players via standard DOM removal methods: this will leave listeners and other objects in memory that you might not be able to clean up!
2019-08-29 18:42:16 -04:00
### Checking if a Player is Disposed
At times, it is useful to know whether or not a player reference in your code is stale. The `isDisposed()` method is available on all components (including players) for this purpose.
2016-12-02 14:27:59 -05:00
### Signs of an Undisposed Player
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
Seeing an error such as:
2016-12-20 16:55:59 -05:00
```console
2016-12-02 14:27:59 -05:00
TypeError: this.el_.vjs_getProperty is not a function
```
or
2016-12-20 16:55:59 -05:00
```console
2016-12-02 14:27:59 -05:00
TypeError: Cannot read property 'vdata1234567890' of null
```
Suggests that a player or component was removed from the DOM without using `dispose()` . It usually means something tried to trigger an event on it or call a method on it.
## Showing and Hiding a Player
2020-12-22 20:10:53 +01:00
It is not recommended that you attempt to toggle the visibility or display of a Video.js player. Instead, players should be created and [disposed ](#removing-players ) as needed.
2016-12-02 14:27:59 -05:00
This is relevant to use cases such as displaying a player in a modal/overlay. Rather than keeping a hidden Video.js player in a DOM element, it's recommended that you create the player when the modal opens and dispose it when the modal closes.
This is particularly relevant where memory/resource usage is concerned (e.g. mobile devices).
Depending on the libraries/frameworks in use, an implementation might look something like this:
```js
modal.on('show', function() {
var videoEl = modal.findEl('video');
modal.player = videojs(videoEl);
});
modal.on('hide', function() {
modal.player.dispose();
});
```
2016-12-20 18:20:31 -05:00
## Changing the volume of a player
Volume for a player can be changed through the `volume` function on a player. The volume function accepts a number from 0-1. Calling it without an argument will return the current volume.
Example
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// get
var howLoudIsIt = myPlayer.volume();
// set
myPlayer.volume(0.5); // Set volume to half
});
```
Volume can also be muted (without actually changing the volume value) using the `muted` function. Calling it without an argument will return the current status of muted on the player.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// get, should be false
console.log(myPlayer.muted());
// set to true
myPlayer.muted(true);
// get should be true
console.log(myPlayer.muted());
});
```
## Making the player fullscreen
To check if the player is currently fullscreen call the `isFullscreen` function on a player like so.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// get, should be false
console.log(myPlayer.isFullscreen());
// set, tell the player it's in fullscreen
myPlayer.isFullscreen(true);
// get, should be true
console.log(myPlayer.isFullscreen());
});
```
To request that the player enter fullscreen call `requestFullscreen` .
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
myPlayer.requestFullscreen();
});
```
To exit fullscreen call `exitFullscreen`
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
myPlayer.requestFullscreen();
myPlayer.exitFullscreen();
});
```
## Using Playback information functions
`play` can be used to start playback on a player that has a source.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
myPlayer.play();
});
```
`pause` can be used to pause playback on a player that is playing.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
myPlayer.play();
myPlayer.pause();
});
```
`paused` can be used to determine if a player is currently paused.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// true
console.log(myPlayer.paused());
// false
console.log(!myPlayer.paused());
myPlayer.play();
// false
console.log(myPlayer.paused());
// true
console.log(!myPlayer.paused());
myPlayer.pause();
// true
console.log(myPlayer.paused());
// false
console.log(!myPlayer.paused());
});
```
`currentTime` will give you the currentTime (in seconds) that playback is currently occuring at.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// set current time to 2 minutes into the video
myPlayer.currentTime(120);
// get the current time, should be 120 seconds
var whereYouAt = myPlayer.currentTime();
});
```
`duration` will give you the total duration of the video that is playing
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
var lengthOfVideo = myPlayer.duration();
});
```
`remainingTime` will give you the seconds that are remaing in the video.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
myPlayer.currentTime(10);
// should be 10 seconds less than duration
console.log(myPlayer.remainingTime());
});
```
`buffered` will give you a timeRange object representing the current ranges of time that are ready to be played at a future time.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
var bufferedTimeRange = myPlayer.buffered();
// number of different ranges of time have been buffered.
// Usually 1
var numberOfRanges = bufferedTimeRange.length,
// Time in seconds when the first range starts.
// Usually 0
var firstRangeStart = bufferedTimeRange.start(0),
// Time in seconds when the first range ends
var firstRangeEnd = bufferedTimeRange.end(0),
// Length in seconds of the first time range
var firstRangeLength = firstRangeEnd - firstRangeStart;
});
```
`bufferedPercent` will give you the the current percentage of the video that is buffered.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
// example 0.11 aka 11%
var howMuchIsDownloaded = myPlayer.bufferedPercent();
});
```
## Dealing with the source or the poster on the player
Passing a source to the player via the API. (this can also be done using options)
```js
var myPlayer = videojs('some-player-id');
2017-08-14 22:02:48 +01:00
myPlayer.src('http://www.example.com/path/to/video.mp4');
2016-12-20 18:20:31 -05:00
```
2019-04-29 19:22:48 +01:00
When a string is provided as the source, Video.js will try to infer the video type from the file extension, but this inference will not work in all cases. It is recommended that the source is provided as an object including the type, as below.
2016-12-20 18:20:31 -05:00
**Source Object (or element):** A javascript object containing information
about the source file. Use this method if you want the player to determine if
it can support the file using the type information.
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
```
**Array of Source Objects:** To provide multiple versions of the source so
that it can be played using HTML5 across browsers you can use an array of
source objects. Video.js will detect which version is supported and load that
file.
```js
var myPlayer = videojs('some-player-id');
myPlayer.src([
2019-04-29 19:22:48 +01:00
{type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'},
{type: 'video/webm', src: 'http://www.example.com/path/to/video.webm'},
{type: 'video/ogg', src: 'http://www.example.com/path/to/video.ogv'}
2016-12-20 18:20:31 -05:00
]);
```
Changing or setting the poster via the API. (this can also be done with options)
```js
var myPlayer = videojs('example_video_1');
// set
myPlayer.poster('http://example.com/myImage.jpg');
// get
console.log(myPlayer.poster());
// 'http://example.com/myImage.jpg'
```
2020-08-06 07:42:34 +02:00
## Accessing the Tech on the player
2016-12-20 18:20:31 -05:00
2021-03-23 22:40:49 +01:00
The tech on the player can be accessed via `tech()` . Passing any argument will silence the warning that is logged.
2016-12-20 18:20:31 -05:00
```js
var myPlayer = videojs('some-player-id');
2019-04-29 19:22:48 +01:00
myPlayer.src({type: 'video/mp4', src: 'http://www.example.com/path/to/video.mp4'});
2016-12-20 18:20:31 -05:00
myPlayer.ready(function() {
2021-03-23 22:40:49 +01:00
// tech() will log warning without any argument
var tech = myPlayer.tech(false);
2016-12-20 18:20:31 -05:00
});
```
2016-12-02 14:27:59 -05:00
## Using Video.js with...
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
### jQuery
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
### React
2016-12-20 16:55:59 -05:00
2017-03-21 17:13:06 -04:00
See [ReactJS integration example ](/docs/guides/react.md )
2017-01-26 22:16:52 +01:00
2016-12-02 14:27:59 -05:00
### Ember
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
### Angular
2019-03-29 12:56:29 +13:00
2022-02-08 22:47:58 +08:00
See [Angular integration example ](/docs/guides/angular.md )
2019-03-29 12:56:29 +13:00
### Vue
See [Vue integration example ](/docs/guides/vue.md )