Calendar日历
Calendar
日历
按照日历形式展示数据的容器。
使用import{ Calendar }from"antd";  | 
当数据是日期或按照日期划分时,例如日程、课表、价格日历等,农历等。目前支持年/月切换。
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
27  | 28  | 29  | 30  | 31  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
10  | 11  | 12  | 13  | 14  | 15  | 16  | 
17  | 18  | 19  | 20  | 21  | 22  | 23  | 
24  | 25  | 26  | 27  | 28  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
27  | 28  | 29  | 30  | 31  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08 
  | 09  | 
10 
  | 11  | 12  | 13  | 14  | 15 
  | 16  | 
17  | 18  | 19  | 20  | 21  | 22  | 23  | 
24  | 25  | 26  | 27  | 28  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08 
  | 09  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
27  | 28  | 29  | 30  | 31  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
10  | 11  | 12  | 13  | 14  | 15  | 16  | 
17  | 18  | 19  | 20  | 21  | 22  | 23  | 
24  | 25  | 26  | 27  | 28  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
26  | 27  | 28  | 29  | 30  | 31  | 01  | 
02  | 03  | 04  | 05  | 06  | 07  | 08  | 
09  | 10  | 11  | 12  | 13  | 14  | 15  | 
16  | 17  | 18  | 19  | 20  | 21  | 22  | 
23  | 24  | 25  | 26  | 27  | 28  | 29  | 
30  | 31  | 01  | 02  | 03  | 04  | 05  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
27 廿八  | 28 廿九  | 29 春节  | 30 初二  | 31 初三  | 1 初四  | 2 初五  | 
3 立春  | 4 初七  | 5 初八  | 6 初九  | 7 初十  | 8 十一  | 9 十二  | 
10 十三  | 11 十四  | 12 十五  | 13 十六  | 14 十七  | 15 十八  | 16 十九  | 
17 二十  | 18 雨水  | 19 廿二  | 20 廿三  | 21 廿四  | 22 廿五  | 23 廿六  | 
24 廿七  | 25 廿八  | 26 廿九  | 27 三十  | 28 初一  | 1 初二  | 2 初三  | 
3 初四  | 4 初五  | 5 惊蛰  | 6 初七  | 7 初八  | 8 初九  | 9 初十  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | |
|---|---|---|---|---|---|---|---|
5  | 27  | 28  | 29  | 30  | 31  | 01  | 02  | 
6  | 03  | 04  | 05  | 06  | 07  | 08  | 09  | 
7  | 10  | 11  | 12  | 13  | 14  | 15  | 16  | 
8  | 17  | 18  | 19  | 20  | 21  | 22  | 23  | 
9  | 24  | 25  | 26  | 27  | 28  | 01  | 02  | 
10  | 03  | 04  | 05  | 06  | 07  | 08  | 09  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | |
|---|---|---|---|---|---|---|---|
5  | 27  | 28  | 29  | 30  | 31  | 01  | 02  | 
6  | 03  | 04  | 05  | 06  | 07  | 08  | 09  | 
7  | 10  | 11  | 12  | 13  | 14  | 15  | 16  | 
8  | 17  | 18  | 19  | 20  | 21  | 22  | 23  | 
9  | 24  | 25  | 26  | 27  | 28  | 01  | 02  | 
10  | 03  | 04  | 05  | 06  | 07  | 08  | 09  | 
| 一 | 二 | 三 | 四 | 五 | 六 | 日 | 
|---|---|---|---|---|---|---|
27  | 28  | 29  | 30  | 31  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
10  | 11  | 12  | 13  | 14  | 15  | 16  | 
17  | 18  | 19  | 20  | 21  | 22  | 23  | 
24  | 25  | 26  | 27  | 28  | 01  | 02  | 
03  | 04  | 05  | 06  | 07  | 08  | 09  | 
通用属性参考:通用属性
注意:Calendar 部分 locale 是从 value 中读取,所以请先正确设置 dayjs 的 locale。
// 默认语言为 en-US,所以如果需要使用其他语言,推荐在入口文件全局设置 locale// import dayjs from 'dayjs';// import 'dayjs/locale/zh-cn';// dayjs.locale('zh-cn');<Calendar cellRender={cellRender} onPanelChange={onPanelChange} onSelect={onSelect} />
| 参数 | 说明 | 类型 | 默认值 | 版本 | 
|---|---|---|---|---|
| cellRender | 自定义单元格的内容 | function(current: dayjs, info: { prefixCls: string, originNode: React.ReactElement, today: dayjs, range?: 'start' | 'end', type: PanelMode, locale?: Locale, subType?: 'hour' | 'minute' | 'second' | 'meridiem' }) => React.ReactNode | - | 5.4.0 | 
| dateFullCellRender | 自定义渲染日期单元格,返回内容覆盖单元格,>= 5.4.0 请用 fullCellRender | function(date: Dayjs): ReactNode | - | < 5.4.0 | 
| fullCellRender | 自定义单元格的内容 | function(current: dayjs, info: { prefixCls: string, originNode: React.ReactElement, today: dayjs, range?: 'start' | 'end', type: PanelMode, locale?: Locale, subType?: 'hour' | 'minute' | 'second' | 'meridiem' }) => React.ReactNode | - | 5.4.0 | 
| defaultValue | 默认展示的日期 | dayjs | - | |
| disabledDate | 不可选择的日期,参数为当前 value,注意使用时不要直接修改 | (currentDate: Dayjs) => boolean | - | |
| fullscreen | 是否全屏显示 | boolean | true | |
| showWeek | 是否显示周数列 | boolean | false | 5.23.0 | 
| headerRender | 自定义头部内容 | function(object:{value: Dayjs, type: 'year' | 'month', onChange: f(), onTypeChange: f()}) | - | |
| locale | 国际化配置 | object | (默认配置) | |
| mode | 初始模式 | month | year | month | |
| validRange | 设置可以显示的日期 | [dayjs, dayjs] | - | |
| value | 展示日期 | dayjs | - | |
| onChange | 日期变化回调 | function(date: Dayjs) | - | |
| onPanelChange | 日期面板变化回调 | function(date: Dayjs, mode: string) | - | |
| onSelect | 选择日期回调,包含来源信息 | function(date: Dayjs, info: { source: 'year' | 'month' | 'date' | 'customize' }) | - | info: 5.6.0 | 
| Token 名称 | 描述 | 类型 | 默认值 | 
|---|---|---|---|
| fullBg | 完整日历背景色 | string | #ffffff | 
| fullPanelBg | 完整日历面板背景色 | string | #ffffff | 
| itemActiveBg | 日期项选中背景色 | string | #e6f4ff | 
| miniContentHeight | 迷你日历内容高度 | string | number | 256 | 
| monthControlWidth | 月选择器宽度 | string | number | 70 | 
| yearControlWidth | 年选择器宽度 | string | number | 80 | 
参考 使用自定义日期库。
参考 如何给日期类组件配置国际化。
参考 FAQ 为什么时间类组件的国际化 locale 设置不生效?。
onSelect 事件提供额外的来源信息,你可以通过 info.source 来判断来源:
<CalendaronSelect={(date, { source }) => {if (source === 'date') {console.log('Panel Select:', source);}}}/>