## DatetimePicker 时间选择
时间选择组件通常与 [弹出层](#/popup) 组件配合使用
### 使用指南
在 app.json 或 index.json 中引入组件
```json
"usingComponents": {
"van-datetime-picker": "path/to/vant-weapp/dist/datetime-picker/index"
}
```
### 代码演示
#### 选择完整时间
```html
```
```javascript
Page({
data: {
minHour: 10,
maxHour: 20,
minDate: new Date(),
maxDate: new Date(2019, 10, 1),
currentDate: new Date()
},
onChange(event) {
this.setData({
currentDate: event.detail.value
});
}
});
```
#### 选择日期(年月日)
```html
```
```js
Page({
data: {
currentDate: new Date(),
minDate: new Date()
},
onChange(event) {
this.setData({
currentDate: event.detail.value
});
}
});
```
#### 选择日期(年月)
```html
```
```js
Page({
data: {
currentDate: new Date(),
minDate: new Date()
},
onChange(event) {
this.setData({
currentDate: event.detail.value
});
}
});
```
#### 选择时间
```html
```
```js
Page({
data: {
currentDate: '12:00',
minHour: 9,
maxHour: 23
},
onChange(event) {
this.setData({
currentDate: event.detail.value
});
}
});
```
### API
| 参数 | 说明 | 类型 | 默认值 |
|------|------|------|------|------|
| type | 类型,可选值为 `date`
`time` `year-month` | `String` | `datetime` |
| min-date | 可选的最小时间,精确到分钟 | `Date` | 十年前 |
| max-date | 可选的最大时间,精确到分钟 | `Date` | 十年后 |
| min-hour | 可选的最小小时,针对 time 类型 | `Number` | `0` |
| max-hour | 可选的最大小时,针对 time 类型 | `Number` | `23` |
| min-minute | 可选的最小分钟,针对 time 类型 | `Number` | `0` |
| max-minute | 可选的最大分钟,针对 time 类型 | `Number` | `59` |
| title | 顶部栏标题 | `String` | `''` |
| show-toolbar | 是否显示顶部栏 | `Boolean` | `false` |
| loading | 是否显示加载状态 | `Boolean` | `false` |
| item-height | 选项高度 | `Number` | `44` |
| confirm-button-text | 确认按钮文字 | `String` | `确认` |
| cancel-button-text | 取消按钮文字 | `String` | `取消` |
| visible-item-count | 可见的选项个数 | `Number` | `5` |
### Event
| 事件名称 | 说明 | 回调参数 |
|------|------|------|
| input | 当值变化时触发的事件 | 当前 value |
| change | 当值变化时触发的事件 | 组件实例 |
| confirm | 点击完成按钮时触发的事件 | 当前 value |
| cancel | 点击取消按钮时触发的事件 | - |
### change事件
在`change`事件中,可以获取到组件实例,对组件进行相应的更新等操作:
| 函数 | 说明 |
|------|------|
| getColumnValue(index) | 获取对应列中选中的值 |
| setColumnValue(index, value) | 设置对应列中选中的值 |
| getColumnValues(index) | 获取对应列中所有的备选值 |
| setColumnValues(index, values) | 设置对应列中所有的备选值 |
| getValues() | 获取所有列中被选中的值,返回一个数组 |
| setValues(values) | `values`为一个数组,设置所有列中被选中的值 |