# DatePicker <small>日期选择</small> ## 示例 ### 单日选择 默认情况下,在下拉浮层中单击日期可以选中一个日期。可以配置 [`clearable`](#props-clearable) 属性来允许清除已选值,用 [`placeholder`](#props-placeholder) 属性来配置未选择时的占位文本。 [[ demo src="/demo/date-picker/default.vue" ]] ### 日期范围选择 配置 [`range`](#props-range) 属性时,可以在下拉浮层中选择一个日期范围。 [[ demo src="/demo/date-picker/range.vue" ]] ### 设置快捷选项 选择日期范围时,可以通过配置 [`shortcuts`](#props-shortcuts) 属性来提供快捷选项。 [[ demo src="/demo/date-picker/shortcuts.vue" ]] ### 禁用和只读 设置 [`disabled`](#props-disabled) 属性可使组件处于禁用状态。 设置 [`readonly`](#props-readonly) 属性可使组件处于只读状态。 [[ demo src="/demo/date-picker/disabled.vue" ]] ## API ### 属性 | 名称 | 类型 | 默认值 | 描述 | | -- | -- | -- | -- | | ``type`` | `string` | `'date'` | 日历的类型,可用值为 `'date'` / `'month'` / `'year'`,分别对应日期/月/年视图。 | | ``range`` | `boolean` | `false` | 是否选择日期范围。 | | ``selected`` | `Date | Array` | - | [^selected] | | ``today`` | `Date` | `new Date()` | 「今天」的日期。 | | ``week-start`` | `number` | `calendar.weekStart` | 一周的起始。可进行[全局配置](./calendar#configs-calendar-weekStart)。 | | ``fill-month`` | `boolean` | `true` | 当只有一个面板时,是否要在当前月份面板显示非本月日期。 | | ``date-class`` | `string | Array | Object | function` | `{}` | 特定日期的自定义 HTML `class`。传非函数时,数据格式为所有 Vue 支持的 `class` 表达式;传函数时,签名为 `function(Date): string | Array<string>|Object<string, boolean>`,返回值格式亦为所有 Vue 支持的 `class` 表达式。 | | ``disabled-date`` | `function(Date, Date=): boolean=` | `() => false` | 用于自定义指定日期是否禁用。第一个参数为需要判断是否禁用的日期。当处于范围选择过程中且已经选择了一个日期,会作为第二个参数传入。 | | ``clearable`` | `boolean` | `false` | 已选值是否可以清除。 | | ``placeholder`` | `string` | `range ? datepicker.rangePlaceholder : datepicker.placeholder` | 未选择时的占位文本。可分别对[日期范围](#configs-datepicker-rangePlaceholder)与[单个日期](#configs-datepicker-placeholder)进行全局配置。 | | ``format`` | `string | function(Date): string=` | `'yyyy-MM-dd'` / `'yyyy-MM'` / `'yyyy'` | 使用字符串时,表示用于格式化/解析的字符串表达式,具体格式可以参见 [date-fns 的文档](https://date-fns.org/v2.12.0/docs/format)。传入函数可自定义格式化逻辑。 | | ``parse`` | `function(string): Date=` | - | 自定义将输入字符串解析为 `Date` 对象的函数。 | | ``shortcuts`` | `Array<Object>` | `datepicker.shortcuts` | [^shortcuts] | | ``expanded`` | `boolean=` | `false` | [^expanded] | | ``disabled`` | `boolean=` | `false` | 是否为禁用状态。 | | ``readonly`` | `boolean=` | `false` | 是否为只读状态。 | ^^^selected :::badges `v-model` ::: 已选日期(范围)的值,根据 [`range`](#props-range) 属性值的不同,数据格式不同。 +++类型详情 | `range` | 类型 | | -- | -- | | `false` | `Date` | | `true` | `[Date, Date]` | +++ ^^^ ^^^shortcuts 在选择范围时,可以定制的浮层中的快捷选择项列表,格式为 `Array<{label, from, to}>`。可进行[全局配置](#configs-datepicker-shortcuts)。 +++字段详情 <table> <thead> <tr> <th>名称</th> <th>类型</th> <th>描述</th> </tr> </thead> <tbody> <tr> <td><code>label</code></td> <td><code>string</code></td> <td>快捷选项的文本。</td> </tr> <tr> <td><code>from</code></td> <td colspan="2">开始时间计算方式,见下方<a href="#快捷选项偏移量数据格式">快捷选项偏移量数据格式</a>描述。</td> </tr> <tr> <td><code>to</code></td> <td colspan="2">结束时间计算方式,见下方<a href="#快捷选项偏移量数据格式">快捷选项偏移量数据格式</a>描述。</td> </tr> </tbody> </table> +++ ^^^ #### 快捷选项偏移量数据格式 `shortcuts` 列表项中的 `from` 及 `to` 字段格式相同,分别用来设置开始结束日期的计算方式。格式为 `number | Object`,默认值为 `0`。 * 类型为 `number` 时,表示以「今天」为基准,偏移指定天数,比如 `-1` 等价于 `{ startOf: 'day', days: -1 }`,即「昨天」; * 类型为 `Object` 时,支持的格式为:`{startOf: string=, days: number=, weeks: number=, months: number=, }`。 +++字段详情 | 名称 | 类型 | 默认值 | 描述 | | -- | -- | -- | -- | | `startOf` | `string=` | `'day'` | 起始日期基准,支持的值有 `'day'` / `'week'` / `'month'` / `'quarter'` / `'year'`。 | | `day` | `number=` | - | 偏移的天数。 | | `week` | `number=` | - | 偏移的周数。 | | `month` | `number=` | - | 偏移的月数。 | | `quarter` | `number=` | - | 偏移的季度数。 | | `year` | `number=` | - | 偏移的年数。 | 计算方式是先根据 `startOf` 设置基准,然后根据其它字段进行偏移量的叠加。 可以根据下面的例子,结合 `label` 理解计算方式。掌握以后,就可以非常快速地对快捷选项进行设置了。 ```js [ { label: '上个月', // 本月第一天往前算一个月,即上月第一天 from: { startOf: 'month', month: -1 }, // 本月第一天往前算一天,即上月最后一天 to: { startOf: 'month', days: -1 } }, { label: '本月', // 本月第一天 from: { startOf: 'month' }, // 今天 to: 0 }, { label: '本周', // 本周第一天,days 为 0 是可以省略的 from: { startOf: 'week', days: 0 }, // 今天 to: 0 }, { label: '最近7天', // 往前算 6 天 from: -6, // 到今天 to: 0 }, { label: '今天', to: 0 } ] ``` ^^^expanded :::badges `.sync` ::: 下拉浮层是否展开。 ^^^ ### 插槽 | 名称 | 描述 | | -- | -- | | ``date`` | [^slot-date] | ^^^slot-date 浮层中日历的单日单元格内的区域,可用来定制每一天对应区域的内容。 默认内容:对应日期的 `date`。 +++作用域参数 | 名称 | 类型 | 描述 | | -- | -- | -- | | `year` | `number` | 完整年份。 | | `month` | `number` | 月份数,`0` 表示一月。 | | `date` | `number` | 月份内的日期。 | +++ ^^^ ### 事件 | 名称 | 描述 | | -- | -- | | ``select`` | [^event-select] | | ``selectstart`` | 选择日期范围时,选择完起始日期时触发,回调参数 `(picking: Date)`,表示已选的起始项日期。 | | ``selectprogress`` | [^event-selectprogress] | | ``toggle`` | 下拉浮层展开状态切换时触发,回调参数为 `(expanded: boolean)`。`expanded` 表示操作将触发下拉浮层展开还是收起。 | ^^^event-select :::badges `v-model` ::: 选择修改后触发,回调参数为 `(selected)`。数据类型和 [`selected`](#props-selected) 属性一致。 ^^^ ^^^event-selectprogress 选择日期范围时,在已经选择开始日期后,通过鼠标或键盘交互标记到的结束日期变更时触发。回调参数为 `(picking)`,表示当前标记的日期范围,类型取决于 [`multiple`](#props-multiple) 属性的值。 +++参数详请 | `multiple` | 类型 | | -- | -- | | `false` | `[Date, Date]` | | `true` | `Array<[Date, Date]>` | +++ ^^^ ### 全局配置 | 配置项 | 类型 | 默认值 | 描述 | | -- | -- | -- | -- | | ``datepicker.shortcuts`` | `Array` | `[]` | 快捷选项配置。 | | ``datepicker.placeholder`` | `string` | `@@datepicker.selectDate` | 选择单日时,未选择状态的占位文本。 | | ``datepicker.monthPlaceholder`` | `string` | `@@datepicker.selectMonth` | 选择月份时,未选择状态的占位文本。 | | ``datepicker.yearPlaceholder`` | `string` | `@@datepicker.selectYear` | 选择年时,未选择状态的占位文本。 | | ``datepicker.rangePlaceholder`` | `string` | `@@datepicker.selectRange` | 选择日期范围时,未选择状态的占位文本。 | | ``datepicker.monthRangePlaceholder`` | `string` | `@@datepicker.selectMonthRange` | 选择月份范围时,未选择状态的占位文本。 | | ``datepicker.yearRangePlaceholder`` | `string` | `@@datepicker.selectYearRange` | 选择年份范围时,未选择状态的占位文本。 | :::tip `@@` 开头的值表示引用多语言配置中的相应字段。 ::: ### 图标 | 名称 | 描述 | | -- | -- | | ``calendar`` | 日历。 | | ``clear`` | 清除内容。 |