Vue Time Picker
A dropdown time picker (hour|minute|second) for Vue.js (1.x), with flexible time format support
🎉 The brand new version for Vue 2.x is up!
Please check vue2-timepicker for your Vue 2.x project
Demo
You can see the vue-timepicker
in action in the Demo Page
Dependencies
Vue.js 1.x (>=v1.0.21 <2.0.0)
Installation
Through NPM (recommended)
npm install vue-time-picker --save
Bower
bower install vue-timepicker --save
Get Started
Step 1: Import VueTimepicker
A. Include with modules
import VueTimepicker from 'vue-time-picker'
var VueTimepicker = require('vue-time-picker')
B. Include with <script>
and <style>
Just put the vue-timepicker.min.js
(or vue-timepicker.js
) script block after Vue itself
Vue.use(window.VueTimepicker)
Step 2: Include VueTimepicker in your component
var yourComponent = new Vue({
components: {VueTimepicker},
...
})
Step 3: Then, you can introduce the vue-timepicker
tag anywhere you like in your component's template
<vue-timepicker></vue-timepicker>
Usage
Basic Usage
<vue-timepicker></vue-timepicker>
Customized Time Format
<vue-timepicker format="HH:mm:ss"></vue-timepicker>
<vue-timepicker format="hh:mm A"></vue-timepicker>
<vue-timepicker format="hh:mm:ss a"></vue-timepicker>
VueTimepicker will recognizes the following tokens in the format string
Section | Token | Output |
---|
AM/PM | A | AM PM |
| a | am pm
Hour | H | 0 1 ... 22 23
| HH | 00 01 ... 22 23
| h | 1 2 ... 11 12
| hh | 01 02 ... 11 12
| k | 1 2 ... 23 24
| kk | 01 02 ... 23 24
Minute | m | 0 1 ... 58 59
| mm | 00 01 ... 58 59
Second | s | 0 1 ... 58 59
| ss | 00 01 ... 58 59
If not set, format
string will be default to "HH:mm"
Customized Picker interval
<vue-timepicker :minute-interval="5"></vue-timepicker>
<vue-timepicker :second-interval="10"></vue-timepicker>
<vue-timepicker :minute-interval="yourMinuteInterval"></vue-timepicker>
Note: Please do remember to add the :
or v-bind:
sign before the interval properties
Hide Clear Button
<vue-timepicker hide-clear-button></vue-timepicker>
Initalise Time Picker Value
var yourComponent = new Vue({
components: {VueTimepicker},
data: function () {
return {
yourTimeValue: {
HH: "10",
mm: "05",
ss: "00"
},
...
}
},
...
})
<vue-timepicker :time-value.sync="yourTimeValue" format="HH:mm:ss"></vue-timepicker>
Get Time Picker's Current Value
Method 1: Read the two-way synced time-value
variable
<vue-timepicker :time-value.sync="yourTimeValue" format="HH:mm:ss"></vue-timepicker>
console.log(this.yourTimeValue)
Method 2: Listen to the vue-timepicker-update
event
var yourComponent = new Vue({
components: {VueTimepicker},
events: {
'vue-timepicker-update': function (eventData) {
},
...
},
...
})
this.$on('vue-timepicker-update', function (eventData) {
})
Unlike the sync time-value
, which only returns tokens you provided in the initial data (HH
, mm
and ss
in the above case), the vue-timepicker-update
event will return all time format.
In the example above, when picker is set to "14:30:15" in HH:mm:ss format, vue-timepicker-update
will return the following data:
{
HH: "14",
H: "14",
hh: "14",
a: "am",
A: "AM",
h: "14",
kk: "14",
k: "14",
m: "30",
mm: "30",
s: "15",
ss: "15"
}
Whereas the time-value
will only return data with your predefined tokens
{
HH: "14",
mm: "30",
ss: "15"
}
Method 3: Add @change
event handler
<vue-timepicker :time-value.sync="yourTimeValue" @change="changeHandler"></vue-timepicker>
<vue-timepicker :time-value.sync="yourTimeValue" @change="otherChangeHandler($arguments, 'foo', 'bar')"></vue-timepicker>
changeHandler (eventData) {
console.log(eventData)
}
otherChangeHandler (eventData, yourArg1, yourArg2) {
console.log(eventData)
console.log(yourArg1)
console.log(yourArg2)
}
Props API
Prop | Type | Required | Default Value |
---|
format | String | no | "HH:mm" |
minute-interval | Number | no | undefined |
second-interval | Number | no | undefined |
time-value | Object | no | undefined |
hide-clear-button | Boolean | no | false |
Contribution
Please feel free to fork and help developing.
npm install
npm run dev
For detailed explanation on how things work, checkout the webpack guide and docs for vue-loader.
Change Log
Detail changes for each release are documented in CHANGELOG.md
License
MIT