-
Notifications
You must be signed in to change notification settings - Fork 7.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: allow embeds via <video-js> element (#4640)
Add the ability to initialize Video.js with an element named video-js. This is because sometimes, seeing the native element is undesirable, plus, it's cool to have our own element. Can be used just like the video embed. IE9 is supported but only with dynamic sources as the source element can only be used inside of the video element.
- Loading branch information
Showing
7 changed files
with
450 additions
and
7 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
# How to Embed the Video.js player | ||
|
||
Video.js is meant to be an enhacement to the video element in HTML5 so for years, its embed code has been just a `<video>` element. | ||
Video.js then wraps the video element in a div that is used for us to place controls and anything else that's required for the player. | ||
|
||
For a long time this was enough. In 2016, "div ingest" was added, it allows the developer to give Video.js a player div to use instead of making it's own. | ||
This is partly to help with content reflow but also to help with iOS where you sometimes need to prime the video element and we re-create the video element when we create the player div. | ||
However, this is kind of weird to have a `<video>` element embed with a `<div>` wrapped around it. So, we built out a new embed, a `<video-js>` embed. | ||
|
||
Below, the three kinds of embeds are detailed. | ||
|
||
## Embeds | ||
### `<video>` embed | ||
The classic Video.js embed. You can then initialize it via `data-setup` or via the `videojs` method. | ||
|
||
```html | ||
<!-- via data-setup --> | ||
<video id="vid1" class="video-js" data-setup='{}'> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video> | ||
|
||
<!-- via code --> | ||
<video id="vid1" class="video-js"> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video> | ||
``` | ||
```js | ||
const player = videojs('vid1', {}); | ||
``` | ||
|
||
### Player div ingest | ||
The enhanced classic embed. You can also initialize it via `data-setup` or via `videojs` method. | ||
|
||
```html | ||
<!-- via data-setup --> | ||
<div data-vjs-player> | ||
<video id="vid1" class="video-js" data-setup='{}'> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video> | ||
</div> | ||
|
||
<!-- via code --> | ||
<div data-vjs-player> | ||
<video id="vid1" class="video-js"> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video> | ||
</div> | ||
``` | ||
```js | ||
const player = videojs('vid1', {}); | ||
``` | ||
|
||
As you can see, it isn't much different from the classic `<video>` embed. It also does make it easier to work with [React](/docs/guides/react.md). | ||
|
||
### `<video-js>` embed | ||
This is the [I Can't Believe It's Not Custom Elements](https://developers.google.com/web/fundamentals/web-components/customelements) embed code. | ||
It looks very much like the `<video>` embed but instead of `video` it's a `video-js` embed. | ||
This is useful for all the things that the player div ingest is useful for and it matches our library name! | ||
|
||
```html | ||
<!-- via data-setup --> | ||
<video-js id="vid1" data-setup='{}'> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video-js> | ||
|
||
<!-- via code --> | ||
<video-js id="vid1"> | ||
<source src="//vjs.zencdn.net/v/oceans.mp4"> | ||
</video-js> | ||
``` | ||
```js | ||
const player = videojs('vid1', {}); | ||
``` | ||
|
||
Adding `class="video-js"` with this embed is no longer necessary as it will automatically add the class `video-js` if missing. | ||
|
||
#### Custom Elements | ||
Native Custom Elements support is relativly small according to [Can I Use](http://caniuse.com/#feat=custom-elementsv1) and because we didn't want to include a polyfill we're going with just an element called `video-js` rather than a full blown custom element. | ||
|
||
#### Browser support | ||
These all work in all browsers that Video.js supports, though, there are some caveats for some older browsers. | ||
- IE8 requires running `document.createElement('video-js')` before using the `video-js` embed code. | ||
- IE9 doesn't support having `source` elements outside of the `video` element, thus, the `video-js` embed will not work there. Though, if the source is set later, it should still work. | ||
|
||
## data-setup | ||
This is an ease-of-use method for having Video.js set up the player automatically. It is an HTML attribute and it takes a JSON string representation of the [player options](/docs/guides/options.md) as the value. | ||
Using the programmatic approach is probably preferable. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,165 @@ | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<meta charset="utf-8" /> | ||
<title>Video.js Sandbox</title> | ||
<script src='../node_modules/es5-shim/es5-shim.js'></script> | ||
<script src='../node_modules/es6-shim/es6-shim.js'></script> | ||
|
||
<link href="../build/temp/video-js.css" rel="stylesheet" type="text/css"> | ||
<script src="../dist/video.js"></script> | ||
|
||
<script src='../node_modules/videojs-flash/dist/videojs-flash.js'></script> | ||
<script src="https://unpkg.com/videojs-contrib-hls@latest/dist/videojs-contrib-hls.js"></script> | ||
|
||
<script src="../build/temp/lang/es.js"></script> | ||
|
||
<!-- Set the location of the flash SWF --> | ||
<script> | ||
// videojs.options.flash.swf = 'http://vjs.zencdn.net/swf/5.3/video-js.swf'; | ||
videojs.options.flash.swf = 'http://localhost:8000/video-js-swf/dist/video-js.swf'; | ||
</script> | ||
<style> | ||
.source-el { background: #FF6961; } | ||
.source-js { background: #77DD77; } | ||
.options-src { background: #AEC6CF; } | ||
.source-el.data-setup { background: red; } | ||
.source-js.data-setup { background: green; } | ||
.options-src.data-setup { background: blue; } | ||
|
||
.video-js { | ||
height: 150px; | ||
width: 300px; | ||
} | ||
|
||
.wrapper { | ||
display: grid; | ||
margin: 0 auto; | ||
grid-gap: 10px; | ||
grid-template-columns: 300px 300px 300px; | ||
} | ||
.panel > p:first-child { | ||
border-bottom: black 1px solid; | ||
} | ||
</style> | ||
</head> | ||
<body> | ||
<p>All the various ways to embed and source video elements.</p> | ||
<p>Pastel color background represent programmatic setup.</p> | ||
<p>Vibrant color background represent data-setup.</p> | ||
<div class="wrapper"> | ||
<div class="panel source-el"> | ||
<p>js setup with source element</p> | ||
<p>video-js embed", source element</p> | ||
<video-js id="vid01" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video-js> | ||
<p>Video embed, source element</p> | ||
<video id="vid11" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video> | ||
<p>injested div el, source element</p> | ||
<div data-vjs-player> | ||
<video id="vid21" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video> | ||
</div> | ||
</div> | ||
<div class="panel options-src"> | ||
<p>js setup with sources options</p> | ||
<p>video-js embed", js source</p> | ||
<video-js id="vid05" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
</video-js> | ||
<p>Video embed, js source</p> | ||
<video id="vid15" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
</video> | ||
<p>injested div el, js source</p> | ||
<div data-vjs-player> | ||
<video id="vid25" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png"> | ||
</video> | ||
</div> | ||
</div> | ||
<div class="panel source-js"> | ||
<p>js setup with js method sources</p> | ||
<p>video-js embed", js source</p> | ||
<video-js id="vid02" class="video-js" controls> | ||
</video-js> | ||
<p>Video embed, js source</p> | ||
<video id="vid12" class="video-js" controls> | ||
</video> | ||
<p>injested div el, js source</p> | ||
<div data-vjs-player> | ||
<video id="vid22" class="video-js" controls> | ||
</video> | ||
</div> | ||
</div> | ||
<div class="panel source-el data-setup"> | ||
<p>data-setup with sourrce elements</p> | ||
<p>video-js embed", source element</p> | ||
<video-js id="vid03" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video-js> | ||
<p>Video embed, source element</p> | ||
<video id="vid13" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video> | ||
<p>injested div el, source element</p> | ||
<div data-vjs-player> | ||
<video id="vid23" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
<source src="./oceans.mp4" type='video/mp4'> | ||
</video> | ||
</div> | ||
</div> | ||
<div class="panel options-src data-setup"> | ||
<p>data-setup embeds with sources options</p> | ||
<p>video-js embed", source element</p> | ||
<video-js id="vid04" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup='{"sources": [{"src":"./oceans.mp4", "type":"video/mp4"}]}'> | ||
</video-js> | ||
<p>Video embed, source element</p> | ||
<video id="vid14" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup='{"sources": [{"src":"./oceans.mp4", "type":"video/mp4"}]}'> | ||
</video> | ||
<p>injested div el, source element</p> | ||
<div data-vjs-player> | ||
<video id="vid24" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup='{"sources": [{"src":"./oceans.mp4", "type":"video/mp4"}]}'> | ||
</video> | ||
</div> | ||
</div> | ||
<div class="panel source-js data-setup"> | ||
<p>js setup with js method sources</p> | ||
<p>video-js embed", js source</p> | ||
<video-js id="vid06" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
</video-js> | ||
<p>Video embed, js source</p> | ||
<video id="vid16" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
</video> | ||
<p>injested div el, js source</p> | ||
<div data-vjs-player> | ||
<video id="vid26" class="video-js" controls poster="//vjs.zencdn.net/v/oceans.png" data-setup="{}"> | ||
</video> | ||
</div> | ||
</div> | ||
</div> | ||
<script> | ||
var player01 = videojs('vid01'); | ||
var player11 = videojs('vid11'); | ||
var player21 = videojs('vid21'); | ||
var player01 = videojs('vid02'); | ||
var player11 = videojs('vid12'); | ||
var player21 = videojs('vid22'); | ||
var player05 = videojs('vid05', {sources: [{src:'./oceans.mp4',type:'video/mp4'}]}); | ||
var player15 = videojs('vid15', {sources: [{src:'./oceans.mp4',type:'video/mp4'}]}); | ||
var player25 = videojs('vid25', {sources: [{src:'./oceans.mp4',type:'video/mp4'}]}); | ||
player01.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
player11.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
player21.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
player01.poster('//vjs.zencdn.net/v/oceans.png'); | ||
player11.poster('//vjs.zencdn.net/v/oceans.png'); | ||
player21.poster('//vjs.zencdn.net/v/oceans.png'); | ||
setTimeout(function() { | ||
videojs.players.vid06 && videojs.players.vid06.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
videojs.players.vid16 && videojs.players.vid16.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
videojs.players.vid26 && videojs.players.vid26.src({src:'./oceans.mp4', type:'video/mp4'}); | ||
}); | ||
</script> | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.