UNPKG

zent

Version:

一套前端设计语言和基于React的实现

137 lines (112 loc) 7.16 kB
--- title: DatePicker path: component/datepicker group: Data Entry --- ## DatePicker Time pickers, provides basic time choosing functionality. ## Guides - Four pickers:`DatePicker`, `MonthPicker`, `WeekPicker` and `RangePicker`. - `DatePicker` and `RangePicker` can use `showTime` to allow time selection. - Date formats can be customized using `format`, you can find formating details at the end of this page. ## API ### Common API | Property | Description | Type | Default | Required | | ------------ | ------------------------ | -------------- | --------------- | ---- | | onChange | Callback when value changes | func | `noop` | 是 | | value | Selected value | string \| Date | | Yes | | defaultValue | Default value | string \| Date | | No | | onClick | Callback when click on a value | func | | No| | openPanel | Is picker visible | boolean | false | No| | onOpen | Callback when picker is opened | func | | No| | onClose | Callback when picker is closed | func | | No| | disabled | Disable picker | bool | `false` | No | | format | Date format string | string | Different pickers have different values | No | | placeholder | Placeholder text | string | Differenet pickers have different values | No | | className | Cusotm class name | string | | No | | width | width | string \| number | | No | | prefix | Custom prefix | string | `'zent'` | No | | confirmText | Confirm button text | string | '确定' | No | | popPosition | Popup align position | oneOf(['left', 'right']) | 'left' | No | ### DatePicker | Property | Description | Type | Default | Required | | ------------ | ------------------------ | -------------- | --------------- | ---- | | showTime | Show or hide time selection | bool | `false` | No | | disabledTime | Callback to check if specific time is disabled | func | `noop` | No | | disabledDate | Callback to check if specific date is disabled | func | `noop` | No | | format | Date formating string | string | `YYYY-MM-DD` | No | | min | The minimium selectable date | string/Date | | No | | max | The maximum selectable date | string/Date | | No | | valueType | Set `onChange`'s value type, one of `string`/`number`/`date` | string | '' | No | | name | Name attribute of the input node | string | | No | | placeholder | Placeholder text | string | `请选择日期` | No | | defaultTime | Default time value | string | `'00:00:00'` | No | | onBeforeConfirm | Confirm callback, return `true` to allow, `false` to abort | func | | No | | onBeforeClear | Clear callback, return `true` to allow, `false` to abort | func | | No | - `disabledDate` will be passed a date object as argument, return true if the date should be disabled. Using `max` and `min` can cover most use cases. - If both `min`/`max` and `disabledDate` are present, `disabledDate` takes precedence. - Return value of `disabledDate` is an object, there are three functions within this object: `disabledHour`, `disabledMinute` and `disabledSecond`. - Only date format is allowed in `format`, time format will be appended when `showTime` is `true`. ### WeekPicker | Property | Description | Type | Default | Required | | ------------ | ------------------------ | -------------- | --------------- | ---- | | startDay | Start day of a week | number | 1 | No | | disabledDate | Callback to check if date is disabled | func | `noop` | No | | format | Date format string | string | `YYYY-MM-DD` | No | | min | Minimum selectable date | string/Date | | No | | max | Maximum seletable date | string/Date | | No | | valueType | Value type in `onChange`, one of `string` \| `number` \| `date` | string | '' | No | | name | Name attribute of input node | string | | No | | placeholder | Placeholder text | string | `请选择日期` | No | | defaultTime | Default time value | string | `'00:00:00'` | No | ### MonthPicker | Property | Description | Type | Default | Required | | ------------ | ------------------------ | -------------- | --------------- | ---- | | value | Selected month | string/Date | `new Date()` | No | | format | Format string | string | `'YYYY-MM'` | No | | disabled | Is disabled | bool | `false` | No | | name | Name attribute of input node | string | | No | | placeholder | Placeholder text | string | `请选择月份` | No | ### RangePicker | Property | Description | Type | Default | Required | | ------------ | ---------- | ------ | -------------- | ---- | | type | Range picker type, one of `combine`/`split` | string | `combine` | No | | showTime | Show time selection | bool | `false` | No | | value | Selected value | array | `[]` | No | | format | Format string | string | `'YYYY-MM-DD'` | No | | disabledDate | Callback to check date is selectable | func | `noop` | No | | disabledTime | Callback to check time is selectable | func | `noop` | No | | min | Minimum selectable date | string/instanceOf(Date) | `` | No | | max | Maximum selectable date | string/instanceOf(Date) | `` | No | | valueType | Value type of `onChange`, one of `string`/`number`/`date` | string | '' | No | | placeholder | Placeholder text | array | `['开始日期','结束日期']` | No | | defaultTime | Default time value | string | `'00:00:00'` | No | - Recommended `type` is `split`. - When `showTime` is `true`, the `min` and `max` string must have time part, e.g. `2017-01-01 11:11:11`. - `disabledTime` has an additional argument `type` like in `DatePicker`, its value is `start` or `end`. - `onClick(val, type)`, the `type` is the same as `disabledTime`. ### Format string | | Format character | Output | | -------- | -------- | -------- | | **Year** | YY | 70 71 ... 29 30 | | | YYYY | 1970 1971 ... 2029 2030 | | **Month** | M | 1 2 ... 11 1 | | | MM | 01 02 ... 11 12 | | | MMM | 1月, 2月 ... 11月, 12月 | | | MMMM | 一月, 二月 ... 十一月, 十二月 | | **Date** | D | 1 2 ... 30 31 | | | DD | 01 02 ... 30 31 | | | d | 0 1 ... 5 6 | | | ddd | 周日, 周一 ... 周五, 周六 | | | dddd | 星期日, 星期一 ... 星期五, 星期六 | <style> .zent-picker-demo{ margin-bottom: 10px; margin-right: 10px; } .demo-subtitle{ margin-bottom: 5px; font-size: 12px; color: #666; } </style>