A simple video component built for vue.
Work fine on IE 11+, Chrome, firefox, ipad and it's mobile friendly.
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.
v0.4.6
🐛 Bug Fix
- Fix #2
npm install vue-video-module -D
// import
import Vue from 'vue';
import VueVideo from 'vue-video-module';
// require
var Vue = require('Vue');
var VueVideo = require('vue-video-module');
// mount with component
export default {
components: {
VueVideo,
},
};
<div class="video-container">
<vue-video ref="video1" :options="videoOptions"></vue-video>
</div>
// e.g
videoOptions: {
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,
},
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 |
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 |
the vueVideo
is the object of this component
// e.g
vueVideo.play();
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 |
- add options for manually set width and height
- add last frame
- add buffering state to progress bar