vue-video-module
A simple video component built for vue.
Work fine on IE 11+, Chrome, firefox, ipad and it's mobile friendly.
Warning
For umd users, due to webpack2 compile changes. The module export compile way changes, so you have no choice but set VueVideo = VueVideo.default
at the begining.
Changelog
v0.4.6
🐛 Bug Fix
- Fix #2
Example
Test
Usage
Install vue-video-module
npm install vue-video-module -D
Vue use
// import;; // requirevar Vue = ;var VueVideo = ; // mount with component components: VueVideo ;
Use in component
<div class="video-container"> <vue-video ref="video1" :options="videoOptions"></vue-video></div>
// e.gvideoOptions: src: 'http://vjs.zencdn.net/v/oceans.mp4' poster: 'http://www.freemake.com/blog/wp-content/uploads/2015/06/videojs-logo.jpg' controlBar: true spinner: 'circles' fullscreen: true
API
Props
Below are properties you can use in videoOptions to construct your own video.
If the value is false means this part will not be rendered.
Name | Description | Value | Default |
---|---|---|---|
src | the source of video | string (required) | null |
poster | the poster of the video | string || false | false |
playMain | the source of main play button | string || false | base64 |
playMainRollover | the source of main play button rollover state | string || false | base64 |
replayMain | the source of main replay button | string || false | base64 |
replayMainRollover | the source of main replay button rollover state | string || false | base64 |
playSub | the source of play button in the video control bar | string | base64 |
pauseSub | the source of pause button in the video control bar | string | base64 |
replaySub | the source of replay button in the video control bar | string | base64 |
fullscreen | if fullscreen part shown | bool | true |
fullscreenSub | the source of full screen button in the video control bar | string || false | base64 |
shrinkscreenSub | the source to shrink screen to normal size, button in the video control bar | string | base64 |
autoPlay | if the video auto play | bool | false |
loop | loop video | bool | false |
muted | muted video | bool | false |
controlBar | if show the controlbar | bool | true |
spinner | the loading style, check here | string | 'circles' |
volume | show the volume controller | bool | true |
aspect | define the video's width and height, an object with 'width' and 'height' property, see example4 for details | object || false | false |
endFrame | show when last frame is shown | string || false | false |
bufferingBar | show the buffering state of the video | bool | false |
timeProgress | show currentTime & totalTime when playing | bool | false |
Events
brief:
the vueVideo
is the object of this component
vueVideo.$refs.video
is the dom of the video
// e.g<vue-video :options="videoOptions" ref="video" @init="initHandler"></vue-video>
Name | Description | Type |
---|---|---|
init(vueVideo) | be called after the video is initialed. PS: if the video src is changed, this event will fire again. | function |
play(vueVideo) | video status from pause to play | function |
pause(vueVideo) | video status from play to pause | function |
start(vueVideo) | video start | function |
end(vueVideo) | video end | function |
Methods
brief:
the vueVideo
is the object of this component
// e.gvueVideo;
Name | Description | parameter |
---|---|---|
play() | make the video play | null |
pause() | make the video pause | null |
replay() | make the video replay | null |
seek(rate) | 0 <= rate <= 1, jump to a ponit | number |
change(options) | if you want to the props after you create it, use this function. | object |
reset() | reset to original state | null |
loadPoster() | process to load the poster | null |
Todo List
- add options for manually set width and height
- add last frame
- add buffering state to progress bar