2016-11-10 13:46:55 +00:00
< script >
module.exports = {
data() {
return {
pickerOptions1: {
shortcuts: [{
text: 'Today',
onClick(picker) {
picker.$emit('pick', new Date());
}
}, {
text: 'Yesterday',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24);
picker.$emit('pick', date);
}
}, {
text: 'A week ago',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', date);
}
}]
},
pickerOptions2: {
shortcuts: [{
text: 'Last week',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', [start, end]);
}
}, {
text: 'Last month',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
picker.$emit('pick', [start, end]);
}
}, {
text: 'Last 3 months',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
picker.$emit('pick', [start, end]);
}
}]
},
value1: '',
value2: '',
value3: new Date(),
value4: '',
value5: '',
2018-01-18 07:35:31 +00:00
value6: ''
2016-11-10 13:46:55 +00:00
};
}
};
< / script >
2017-05-18 04:28:45 +00:00
< style >
.demo-block.demo-datetime-picker .source {
padding: 0;
display: flex;
}
.demo-datetime-picker .block {
padding: 30px 0;
text-align: center;
border-right: solid 1px #EFF2F6 ;
flex: 1;
& :last-child {
border-right: none;
}
}
.demo-datetime-picker .demonstration {
display: block;
color: #8492a6 ;
font-size: 14px;
margin-bottom: 20px;
}
< / style >
2016-11-10 13:46:55 +00:00
## DateTimePicker
Select date and time in one picker.
2017-08-05 09:25:51 +00:00
:::tip
DateTimePicker is derived from DatePicker and TimePicker. For a more detailed explanation on `pickerOptions` and other attributes, you can refer to DatePicker and TimePicker.
:::
2016-11-10 13:46:55 +00:00
### Date and time
:::demo You can select date and time in one picker at the same time by setting `type` to `datetime` . The way to use shortcuts is the same as Date Picker.
```html
< template >
< div class = "block" >
< span class = "demonstration" > Default< / span >
< el-date-picker
v-model="value1"
type="datetime"
placeholder="Select date and time">
< / el-date-picker >
< / div >
< div class = "block" >
< span class = "demonstration" > With shortcuts< / span >
< el-date-picker
v-model="value2"
type="datetime"
placeholder="Select date and time"
:picker-options="pickerOptions1">
< / el-date-picker >
< / div >
< / template >
< script >
export default {
data() {
return {
pickerOptions1: {
shortcuts: [{
text: 'Today',
onClick(picker) {
picker.$emit('pick', new Date());
}
}, {
text: 'Yesterday',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24);
picker.$emit('pick', date);
}
}, {
text: 'A week ago',
onClick(picker) {
const date = new Date();
date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', date);
}
}]
},
value1: '',
value2: ''
};
}
};
< / script >
```
:::
### Date and time range
:::demo You can select date and time range by setting `type` to `datetimerange` .
```html
< template >
< div class = "block" >
< span class = "demonstration" > Default< / span >
< el-date-picker
v-model="value3"
type="datetimerange"
2017-09-23 04:46:37 +00:00
range-separator="To"
start-placeholder="Start date"
end-placeholder="End date">
2016-11-10 13:46:55 +00:00
< / el-date-picker >
< / div >
< div class = "block" >
< span class = "demonstration" > With shortcuts< / span >
< el-date-picker
v-model="value4"
type="datetimerange"
:picker-options="pickerOptions2"
2017-09-23 04:46:37 +00:00
range-separator="To"
start-placeholder="Start date"
end-placeholder="End date"
2016-12-28 10:33:45 +00:00
align="right">
2016-11-10 13:46:55 +00:00
< / el-date-picker >
< / div >
< / template >
< script >
export default {
data() {
return {
pickerOptions2: {
shortcuts: [{
text: 'Last week',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
picker.$emit('pick', [start, end]);
}
}, {
text: 'Last month',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
picker.$emit('pick', [start, end]);
}
}, {
text: 'Last 3 months',
onClick(picker) {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
picker.$emit('pick', [start, end]);
}
}]
},
2016-12-29 09:20:59 +00:00
value3: [new Date(2000, 10, 10, 10, 10), new Date(2000, 10, 11, 10, 10)],
2016-11-10 13:46:55 +00:00
value4: ''
};
}
};
< / script >
```
:::
2018-01-18 07:35:31 +00:00
### Default time value for start date and end date
:::demo When picking date range on the date panel with type `datetimerange` , `00:00:00` will be used as the default time value for start and end date. We can control it with the `default-time` attribute. `default-time` accepts an array of up to two strings. The first item controls time value of the start date and the second item controls time value of the end date.
```html
< template >
< div class = "block" >
< span class = "demonstration" > Start date time 12:00:00< / span >
< el-date-picker
v-model="value5"
type="datetimerange"
start-placeholder="Start Date"
end-placeholder="End Date"
:default-time="['12:00:00']">
< / el-date-picker >
< / div >
< div class = "block" >
< span class = "demonstration" > Start date time 12:00:00, end date time 08:00:00< / span >
< el-date-picker
v-model="value6"
type="datetimerange"
align="right"
start-placeholder="Start Date"
end-placeholder="End Date"
:default-time="['12:00:00', '08:00:00']">
< / el-date-picker >
< / div >
< / template >
< script >
export default {
data() {
return {
value5: '',
value6: ''
};
}
};
< / script >
```
:::
2016-11-10 13:46:55 +00:00
### Attributes
| Attribute | Description | Type | Accepted Values | Default |
|---------- |-------------- |---------- |-------------------------------- |-------- |
2016-11-14 10:55:17 +00:00
| readonly | whether DatePicker is read only | boolean | — | false |
2016-12-29 12:53:33 +00:00
| disabled | whether DatePicker is disabled | boolean | — | false |
| editable | whether the input is editable | boolean | — | true |
| clearable | Whether to show clear button | boolean | — | true |
2016-12-08 16:06:34 +00:00
|size | size of Input | string | large/small/mini | — |
2017-09-23 04:46:37 +00:00
| placeholder | placeholder in non-range mode | string | — | — |
| start-placeholder | placeholder for the start date in range mode | string | — | — |
| end-placeholder | placeholder for the end date in range mode | string | — | — |
2017-10-11 10:00:58 +00:00
| time-arrow-control | whether to pick time using arrow buttons | boolean | — | false |
2016-12-13 14:52:29 +00:00
| type | type of the picker | string | year/month/date/datetime/ week/datetimerange/daterange | date |
2018-03-20 06:04:44 +00:00
| format | format of the displayed value in the input box | string | see [date formats ](#/en-US/component/date-picker#date-formats ) | yyyy-MM-dd HH:mm:ss |
2016-11-10 13:46:55 +00:00
| align | alignment | left/center/right | left |
2016-12-20 08:38:47 +00:00
| popper-class | custom class name for DateTimePicker's dropdown | string | — | — |
2016-11-10 13:46:55 +00:00
| picker-options | additional options, check the table below | object | — | {} |
2017-09-23 04:46:37 +00:00
| range-separator | range separator | string | - | '-' |
2017-10-10 09:49:41 +00:00
| default-value | optional, default date of the calendar | Date | anything accepted by `new Date()` | — |
2018-01-18 07:35:31 +00:00
| default-time | the time value to use when selecting date range | string[] | Array with length 2, each item is a string like `12:00:00` . The first item for the start date and then second item for the end date | — |
2018-01-21 09:13:25 +00:00
| value-format | optional, format of binding value. If not specified, the binding value will be a Date object | string | see [date formats ](#/en-US/component/date-picker#date-formats ) | — |
2017-10-10 09:49:41 +00:00
| name | same as `name` in native input | string | — | — |
2017-10-19 06:09:05 +00:00
| unlink-panels | unllink two date-panels in range-picker | boolean | — | false |
2018-01-15 13:50:04 +00:00
| prefix-icon | Custom prefix icon class | string | — | el-icon-date |
| clear-icon | Custom clear icon class | string | — | el-icon-circle-close |
2016-11-10 13:46:55 +00:00
### Picker Options
| Attribute | Description | Type | Accepted Values | Default |
|---------- |-------------- |---------- |-------------------------------- |-------- |
| shortcuts | a { text, onClick } object array to set shortcut options, check the table below | object[] | — | — |
| disabledDate | a function determining if a date is disabled with that date as its parameter. Should return a Boolean | function | — | — |
2017-08-05 09:25:51 +00:00
| firstDayOfWeek | first day of week | Number | 1 to 7 | 7 |
2016-11-10 13:46:55 +00:00
### shortcuts
| Attribute | Description | Type | Accepted Values | Default |
|---------- |-------------- |---------- |-------------------------------- |-------- |
| text | title of the shortcut | string | — | — |
2016-12-13 14:52:29 +00:00
| onClick | callback function, triggers when the shortcut is clicked, with the `vm` as its parameter. You can change the picker value by emitting the `pick` event. Example: `vm.$emit('pick', new Date())` | function | — | — |
2016-12-23 09:34:40 +00:00
### Events
| Event Name | Description | Parameters |
|---------|--------|---------|
2017-10-10 10:06:01 +00:00
| change | triggers when user confirms the value | component's binding value |
2017-12-12 07:46:19 +00:00
| blur | triggers when Input blurs | component instance |
| focus | triggers when Input focuses | component instance |
2017-07-18 05:47:35 +00:00
### Methods
| Method | Description | Parameters |
|------|--------|-------|
2017-10-10 10:06:01 +00:00
| focus | focus the Input component | — |