• DatePicker 日期选择器
    • 概述
    • 代码示例
    • API
      • DatePicker props
      • options
      • DatePicker events
      • DatePicker slot

    DatePicker 日期选择器

    概述

    选择或输入日期,支持年、月、日期等类型,支持选择范围。

    代码示例

    DatePicker 日期选择器 - 图1

    基础用法

    设置属性 typedatedaterange 分别显示选择单日选择范围类型。

    设置属性 placement 可以更改选择器出现的方向,与 Poptip 和 Tooltip 配置一致,支持 12 个方向,详见 API。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="daterange" placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. }
    14. </script>

    DatePicker 日期选择器 - 图2

    快捷方式

    设置属性 options 对象中的 shortcuts 可以设置快捷选项,详见示例代码。

    其中 value 为函数,必须返回一个日期,如果是 daterange 类型,需要返回一个数组。

    value 接收任何正确的日期格式,比如 2016-12-24 或 12/24/16 都是正确的。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" :options="options1" placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="daterange" :options="options2" placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. data () {
    14. return {
    15. options1: {
    16. shortcuts: [
    17. {
    18. text: 'Today',
    19. value () {
    20. return new Date();
    21. },
    22. onClick: (picker) => {
    23. this.$Message.info('Click today');
    24. }
    25. },
    26. {
    27. text: 'Yesterday',
    28. value () {
    29. const date = new Date();
    30. date.setTime(date.getTime() - 3600 * 1000 * 24);
    31. return date;
    32. },
    33. onClick: (picker) => {
    34. this.$Message.info('Click yesterday');
    35. }
    36. },
    37. {
    38. text: 'One week',
    39. value () {
    40. const date = new Date();
    41. date.setTime(date.getTime() - 3600 * 1000 * 24 * 7);
    42. return date;
    43. },
    44. onClick: (picker) => {
    45. this.$Message.info('Click a week ago');
    46. }
    47. }
    48. ]
    49. },
    50. options2: {
    51. shortcuts: [
    52. {
    53. text: '1 week',
    54. value () {
    55. const end = new Date();
    56. const start = new Date();
    57. start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
    58. return [start, end];
    59. }
    60. },
    61. {
    62. text: '1 month',
    63. value () {
    64. const end = new Date();
    65. const start = new Date();
    66. start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
    67. return [start, end];
    68. }
    69. },
    70. {
    71. text: '3 months',
    72. value () {
    73. const end = new Date();
    74. const start = new Date();
    75. start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
    76. return [start, end];
    77. }
    78. }
    79. ]
    80. }
    81. }
    82. }
    83. }
    84. </script>

    DatePicker 日期选择器 - 图3

    面板不联动

    开启属性 split-panels 后,左右两面板在切换年、月时不联动。

    1. <template>
    2. <DatePicker type="daterange" split-panels placeholder="Select date" style="width: 200px"></DatePicker>
    3. </template>
    4. <script>
    5. export default {
    6. }
    7. </script>

    DatePicker 日期选择器 - 图4

    多选

    开启属性 multiple 后,可以多选。

    1. <template>
    2. <DatePicker type="date" multiple placeholder="Select date" style="width: 300px"></DatePicker>
    3. </template>
    4. <script>
    5. export default {
    6. }
    7. </script>

    DatePicker 日期选择器 - 图5

    显示星期数

    开启属性 show-week-numbers 后,可以显示星期数。

    2.10.0 版本开始支持。
    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" show-week-numbers placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="daterange" show-week-numbers placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. }
    14. </script>

    DatePicker 日期选择器 - 图6

    起始日期

    设置属性 start-date 后,可以将默认显示的日期面板设置为指定日期。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" :start-date="new Date(1991, 4, 14)" placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="daterange" :start-date="new Date(1991, 4, 14)" placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. }
    14. </script>

    DatePicker 日期选择器 - 图7

    日期格式

    设置属性 format 可以改变日期的显示格式,详见 Date)。

    注意,format 只是改变显示的格式,并非改变 value 值。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker :value="value1" format="yyyy年MM月dd日" type="date" placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker :value="value2" format="yyyy/MM/dd" type="daterange" placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. data () {
    14. return {
    15. value1: '2016-01-01',
    16. value2: ['2016-01-01', '2016-02-15']
    17. }
    18. }
    19. }
    20. </script>

    DatePicker 日期选择器 - 图8

    日期时间选择

    设置属性 typedatetimedatetimerange 可以选择时间。

    设置 format 并且忽略秒,可以只设置小时和分钟维度。

    1. <template>
    2. <DatePicker type="datetime" placeholder="Select date and time" style="width: 200px"></DatePicker>
    3. <br>
    4. <DatePicker type="datetime" format="yyyy-MM-dd HH:mm" placeholder="Select date and time(Excluding seconds)" style="width: 200px"></DatePicker>
    5. <br>
    6. <DatePicker type="datetimerange" placeholder="Select date and time" style="width: 300px"></DatePicker>
    7. <br>
    8. <DatePicker type="datetimerange" format="yyyy-MM-dd HH:mm" placeholder="Select date and time(Excluding seconds)" style="width: 300px"></DatePicker>
    9. </template>
    10. <script>
    11. export default {
    12. }
    13. </script>

    DatePicker 日期选择器 - 图9

    年和月

    设置属性 typeyearmonth 可以使用选择年或月的功能。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="year" placeholder="Select year" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="month" placeholder="Select month" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. }
    14. </script>

    DatePicker 日期选择器 - 图10

    不可选日期

    设置属性 options 对象中的 disabledDate 可以设置不可选择的日期。

    disabledDate 是函数,参数为当前的日期,需要返回 Boolean 是否禁用这天。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" :options="options3" placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="date" :options="options4" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. data () {
    14. return {
    15. options3: {
    16. disabledDate (date) {
    17. return date && date.valueOf() < Date.now() - 86400000;
    18. }
    19. },
    20. options4: {
    21. disabledDate (date) {
    22. const disabledDay = date.getDate();
    23. return disabledDay === 15;
    24. }
    25. }
    26. }
    27. }
    28. }
    29. </script>

    DatePicker 日期选择器 - 图11

    带有确认操作

    设置属性 confirm,选择日期后,选择器不会主动关闭,需用户确认后才可关闭。

    确认按钮并没有影响日期的正常选择。

    1. <template>
    2. <Row>
    3. <Col span="12">
    4. <DatePicker type="date" confirm placeholder="Select date" style="width: 200px"></DatePicker>
    5. </Col>
    6. <Col span="12">
    7. <DatePicker type="daterange" confirm placement="bottom-end" placeholder="Select date" style="width: 200px"></DatePicker>
    8. </Col>
    9. </Row>
    10. </template>
    11. <script>
    12. export default {
    13. }
    14. </script>

    DatePicker 日期选择器 - 图12

    手动控制组件

    对于一些定制化的场景,可以使用 slot 配合参数 open 及事件来手动控制组件的显示状态,详见示例和 API。

    1. <template>
    2. <DatePicker
    3. :open="open"
    4. :value="value3"
    5. confirm
    6. type="date"
    7. @on-change="handleChange"
    8. @on-clear="handleClear"
    9. @on-ok="handleOk">
    10. <a href="javascript:void(0)" @click="handleClick">
    11. <Icon type="ios-calendar-outline"></Icon>
    12. <template v-if="value3 === ''">Select date</template>
    13. <template v-else>{{ value3 }}</template>
    14. </a>
    15. </DatePicker>
    16. </template>
    17. <script>
    18. export default {
    19. data () {
    20. return {
    21. open: false,
    22. value3: ''
    23. }
    24. },
    25. methods: {
    26. handleClick () {
    27. this.open = !this.open;
    28. },
    29. handleChange (date) {
    30. this.value3 = date;
    31. },
    32. handleClear () {
    33. this.open = false;
    34. },
    35. handleOk () {
    36. this.open = false;
    37. }
    38. }
    39. }
    40. </script>

    DatePicker 日期选择器 - 图13

    尺寸

    通过设置属性 sizelargesmall 可以调整选择器尺寸为大或小,默认不填为中。

    1. <template>
    2. <Row>
    3. <Col span="8">
    4. <DatePicker size="small" type="date" placeholder="Select date"></DatePicker>
    5. </Col>
    6. <Col span="8">
    7. <DatePicker type="date" placeholder="Select date"></DatePicker>
    8. </Col>
    9. <Col span="8">
    10. <DatePicker size="large" type="date" placeholder="Select date"></DatePicker>
    11. </Col>
    12. </Row>
    13. </template>
    14. <script>
    15. export default {
    16. }
    17. </script>

    API

    DatePicker props

    属性说明类型默认值
    type显示类型,可选值为 datedaterangedatetimedatetimerangeyearmonthStringdate
    value 日期,可以是 JavaScript 的 Date,例如 new Date(),也可以是标准的日期格式,点击右边查看 注意:value 使用 v-model 时,值是 Date 类型,可以配合 @on-change 使用 Date)-
    format展示的日期格式 Date)
    - date | daterange:yyyy-MM-dd
    - datetime | datetimerange:yyyy-MM-dd HH:mm:ss
    - year:yyyy
    - month:yyyy-MM
    placement日期选择器出现的位置,可选值为toptop-starttop-endbottombottom-startbottom-endleftleft-startleft-endrightright-startright-end,2.12.0 版本开始支持自动识别Stringbottom-start
    placeholder占位文本String
    options选择器额外配置,比如不可选日期与快捷选项,具体项详见下表Object-
    split-panels开启后,左右面板不联动,仅在 daterangedatetimerange 下可用。Booleanfalse
    multiple开启后,可以选择多个日期,仅在 date 下可用。Booleanfalse
    show-week-numbers开启后,可以显示星期数。Booleanfalse
    start-date设置默认显示的起始日期。Date-
    confirm是否显示底部控制栏,开启后,选择完日期,选择器不会主动关闭,需用户确认后才可关闭Booleanfalse
    open手动控制日期选择器的显示状态,true 为显示,false 为收起。使用该属性后,选择器不会主动关闭。建议配合 slot 及 confirm 和相关事件一起使用Booleannull
    size尺寸,可选值为largesmalldefault或者不设置String-
    disabled是否禁用选择器Booleanfalse
    clearable是否显示清除按钮Booleantrue
    readonly完全只读,开启后不会弹出选择器,只在没有设置 open 属性下生效Booleanfalse
    editable文本框是否可以输入,只在没有使用 slot 时有效Booleantrue
    transfer是否将弹层放置于 body 内,在 Tabs、带有 fixed 的 Table 列内使用时,建议添加此属性,它将不受父级样式影响,从而达到更好的效果Booleanfalse
    element-id给表单元素设置 id,详见 Form 用法。String-
    time-picker-options可以在 type 为 datetime 和 datetimerange 下,配置 TimePicker 的属性,比如时间间隔 steps::time-picker-options="{steps: [1, 10, 10]}"Object{}
    separator 3.3.0两个日期间的分隔符String -

    options

    选择器额外配置

    属性说明类型默认值
    shortcuts 设置快捷选项,每项内容:
    - text | String:显示的文案
    - value | Function:返回指定的日期,如需自己控制逻辑,可不设置,并使用 onClick 回调
    - onClick | Function:点击时的回调,参数为当前日期选择器的 Vue 实例,当需要自定义复杂操作时,可以使用
    Array-
    disabledDate设置不可选择的日期,参数为当前的日期,需要返回 Boolean 是否禁用这天Function-

    DatePicker events

    事件名说明返回值
    on-change日期发生变化时触发返回两个值,已经格式化后的日期,比如 2016-01-01,和当前的日期类型,比如 date
    on-open-change弹出日历和关闭日历时触发true | false
    on-ok在 confirm 模式下有效,点击确定按钮时触发-
    on-clear在 confirm 模式或 clearable = true 时有效,在清空日期时触发-
    on-clickoutside 3.4.0点击外部关闭下拉菜单时触发event

    DatePicker slot

    名称说明
    自定义选择器的显示内容,建议与 open 等参数一起使用,详见示例