6.8 KiB
6.8 KiB
title, description, spline, isComponent
| title | description | spline | isComponent |
|---|---|---|---|
| Calendar 日历 | 按照日历形式展示数据或日期的容器。 | form | true |
该组件于 0.22.0 版本上线,请留意版本。
引入
全局引入,在 miniprogram 根目录下的app.json中配置,局部引入,在需要引入的页面或组件的index.json中配置。
"usingComponents": {
"t-calendar": "tdesign-miniprogram/calendar/calendar"
}
代码演示
Tips: 请确保开发者工具为打开状态。导入开发者工具后,依次执行:npm i > 构建npm包 > 勾选 "将JS编译成ES5"
组件类型
单个选择日历
{{ base }}
多个选择日历
{{ multiple }}
带单行/双行描述的日历
{{ custom-text }}
带翻页功能的日历
{{ switch-mode }}
可选择区间日期的日历
{{ range }}
组件样式
国际化
{{ local-text }}
含不可选的日历
{{ custom-range }}
不使用 Popup
{{ without-popup }}
API
Calendar Props
| 名称 | 类型 | 默认值 | 描述 | 必传 |
|---|---|---|---|---|
| style | Object | - | 样式 | N |
| custom-style | Object | - | 样式,一般用于开启虚拟化组件节点场景 | N |
| auto-close | Boolean | true | 0.34.0。自动关闭;在点击关闭按钮、确认按钮、遮罩层时自动关闭,不需要手动设置 visible |
N |
| confirm-btn | String / Object / Slot | '' | 确认按钮。值为 null 则不显示确认按钮。值类型为字符串,则表示自定义按钮文本,值类型为 Object 则表示透传 Button 组件属性。通用类型定义。详细类型定义 | N |
| first-day-of-week | Number | 0 | 第一天从星期几开始,默认 0 = 周日 | N |
| format | Function | - | 用于格式化日期的函数。TS 类型:CalendarFormatType type CalendarFormatType = (day: TDate) => TDate type TDateType = 'selected' | 'disabled' | 'start' | 'centre' | 'end' | '' interface TDate { date: Date; day: number; type: TDateType; className?: string; prefix?: string; suffix?: string;}。详细类型定义 |
N |
| locale-text | Object | - | 国际化文案。TS 类型:CalendarLocaleText interface CalendarLocaleText {title?: string; weekdays?: string[]; monthTitle?: string; months?: string[]; confirm?: string;}。详细类型定义 |
N |
| max-date | Number | - | 最大可选的日期,不传则默认半年后 | N |
| min-date | Number | - | 最小可选的日期,不传则默认今天 | N |
| switch-mode | String | none | 切换模式。 none 表示水平方向平铺展示所有月份; month 表示支持按月切换, year-month 表示既按年切换,也支持按月切换。可选项:none/month/year-month |
N |
| title | String / Slot | - | 标题,不传默认为“请选择日期”。通用类型定义 | N |
| type | String | 'single' | 日历的选择类型,single = 单选;multiple = 多选; range = 区间选择。可选项:single/multiple/range | N |
| use-popup | Boolean | true | 0.32.0。是否使用弹出层包裹日历 |
N |
| using-custom-navbar | Boolean | false | 是否使用了自定义导航栏 | N |
| value | Number / Array | - | 当前选择的日期,不传则选用 minDate 属性值或今天,优先级:minDate > today。当 type = multiple 或 range 时传入数组。TS 类型:number | number[] |
N |
| default-value | Number / Array | undefined | 当前选择的日期,不传则选用 minDate 属性值或今天,优先级:minDate > today。当 type = multiple 或 range 时传入数组。非受控属性。TS 类型:number | number[] |
N |
| visible | Boolean | false | 是否显示日历;usePopup 为 true 时有效 |
N |
Calendar Events
| 名称 | 参数 | 描述 |
|---|---|---|
| change | (value: timestamp) |
0.28.0。不显示 confirm-btn 时,完成选择时触发(暂不支持 type = multiple) |
| close | (trigger: CalendarTrigger) |
0.34.0。关闭按钮时触发。详细类型定义。type CalendarTrigger = 'close-btn' | 'confirm-btn' | 'overlay' |
| confirm | (value: timestamp) |
点击确认按钮时触发 |
| panel-change | (year: number; month: number) |
1.8.4。切换月或年时触发(switch-mode 不为 none 时有效) |
| scroll | ({scrollLeft, scrollTop, scrollHeight, scrollWidth, deltaX, deltaY}) |
1.4.6。滚动时触发 |
| select | (value: timestamp) |
0.28.0。点击日期时触发 |
CSS Variables
组件提供了下列 CSS 变量,可用于自定义样式。
| 名称 | 默认值 | 描述 |
|---|---|---|
| --td-calendar-active-color | @brand-color | 选中项背景色 |
| --td-calendar-bg-color | @bg-color-container | - |
| --td-calendar-days-color | @text-color-secondary | - |
| --td-calendar-item-centre-color | @brand-color-light | - |
| --td-calendar-item-disabled-color | @text-color-disabled | - |
| --td-calendar-item-suffix-color | @text-color-placeholder | - |
| --td-calendar-radius | 24rpx | - |
| --td-calendar-selected-color | @text-color-anti | - |
| --td-calendar-switch-mode-icon-color | @brand-color | - |
| --td-calendar-switch-mode-icon-disabled-color | @brand-color-disabled | - |
| --td-calendar-title-color | @text-color-primary | - |
| --td-calendar-title-font-size | 18px | - |