ant-design-vue/components/calendar/index.zh-CN.md
Zev Zhu 2ce4e7da82
feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module

* feat: calendar select support info.source param
2023-07-03 21:27:18 +08:00

3.3 KiB
Raw Permalink Blame History

category type title subtitle cover coverDark
Components 数据展示 Calendar 日历 https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*nF6_To7pDSAAAAAAAAAAAAAADrJ8AQ/original https://mdn.alipayobjects.com/huamei_7uahnr/afts/img/A*-p-wQLik200AAAAAAAAAAAAADrJ8AQ/original

按照日历形式展示数据的容器。

何时使用

当数据是日期或按照日期划分时,例如日程、课表、价格日历等,农历等。目前支持年/月切换。

API

**注意:**Calendar 部分 locale 是从 value 中读取,所以请先正确设置 dayjs 的 locale。

// 默认语言为 en-US所以如果需要使用其他语言推荐在入口文件全局设置 locale // import dayjs from
'dayjs'; // import 'dayjs/locale/zh-cn'; // dayjs.locale('zh-cn');

<a-calendar v-model:value="value" @panelChange="onPanelChange" @select="onSelect"></a-calendar>
参数 说明 类型 默认值 版本
dateCellRender 作用域插槽,用来自定义渲染日期单元格,返回内容会被追加到单元格, v-slot:dateCellRender="{current: dayjs}"
dateFullCellRender 作用域插槽,自定义渲染日期单元格,返回内容覆盖单元格 v-slot:dateFullCellRender="{current: dayjs}"
disabledDate 不可选择的日期 (currentDate: dayjs) => boolean
fullscreen 是否全屏显示 boolean true
headerRender 自定义头部内容 v-slot:headerRender="{value: dayjs, type: string, onChange: f(), onTypeChange: f()}" -
locale 国际化配置 object 默认配置
mode 初始模式,month/year string month
monthCellRender 作用域插槽,自定义渲染月单元格,返回内容会被追加到单元格 v-slot:monthCellRender="{current: dayjs}"
monthFullCellRender 作用域插槽,自定义渲染月单元格,返回内容覆盖单元格 v-slot:monthFullCellRender="{current: dayjs}"
validRange 设置可以显示的日期 [dayjs, dayjs]
value(v-model) 展示日期 dayjs 当前日期
valueFormat 可选,绑定值的格式,对 value、defaultValue 起作用。不指定则绑定值为 dayjs 对象 string具体格式 -

事件

事件名称 说明 回调参数
change 日期变化时的回调, 面板变化有可能导致日期变化 function(date: dayjs | string
panelChange 日期面板变化回调 function(date: dayjs | string, mode: string)
select 选择日期回调,包含来源信息 function(date: Dayjs, info: { source: 'year' | 'month' | 'date' | 'customize' }) -

如何仅获取来自面板点击的日期?

select 事件提供额外的来源信息,你可以通过 info.source 来判断来源:

<script lang="ts" setup>
  const onSelect = (date, { source }) => {
    if (source === 'date') {
      console.log('Panel Select:', source);
    }
  };
</script>
<template>
  <a-calendar @select="onSelect" />
</template>