element-plus 日期选择添加确定按钮

需求:选择日期后,点击确定按钮关闭面板

思路:

  1. 使用shortcuts自定义确定和取消按钮
  2. 选择日期后使用handleOpen()强制开启面板
  3. 点击确定后使用handleClose()关闭面板
javascript 复制代码
<template>
    <el-date-picker
        ref="pickerRef"
        v-model="dateValue"
        type="daterange"
        range-separator="To"
        start-placeholder="Start date"
        end-placeholder="End date"
        :shortcuts="shortcuts"
        @change="dateChange"
        @focus="focusChange"
    />
</template>

<script setup>
    import { ref, nextTick } from 'vue'
    import { ElButton, ElDatePicker } from 'element-plus'

    const dateValue = ref('')
    const pickerRef = ref(null)
    let isClickPicker = false
    const shortcuts = ref([
        {
            text: '取消',
            onClick(picker) {
                console.log('点击取消')
                isClickPicker = true
                pickerRef.value && pickerRef.value.handleClose()
                setTimeout(() => {
                    dateValue.value = ''
                }, 10)
            }
        },
        {
            text: '确定',
            onClick(picker) {
                // 关闭面板
                isClickPicker = true
                console.log('点击确定')
                if(!dateValue.value) {
                  // message.warning('请选择日期!')
                  console.log('请选择日期!')
                  return false
                }
                pickerRef.value && pickerRef.value.handleClose()
            }
        }
    ])
    const dateChange = (date) => {
        pickerRef.value && pickerRef.value.handleOpen()
    }
    const focusChange = () => {
        // 点击确定后聚焦,强制关闭面板
        if (isClickPicker) {
            pickerRef.value && pickerRef.value.handleClose()
            isClickPicker = false
        }
    }
</script>

<style>
    .el-picker-panel__body-wrapper {
        height: 108%;
        border: 1px solid #e4e4e4;
        width: 100%;
    }
    .el-date-picker.has-sidebar {
        width: 330px !important;
    }
    .el-picker-panel__sidebar {
        right: 0px;
        top: 310px !important;
        width: 150px;
        display: flex;
    }
    .el-picker-panel__body {
        padding-bottom: 20px;
        margin-left: 0px !important;
    }
</style>
相关推荐
神奇的程序员12 小时前
我的软件冲进苹果商店下载榜前 50 了
前端
阳光是sunny12 小时前
别再被 worktree 绕晕了!AI 编程时代你必须掌握的 Git 隔离神器
前端·人工智能·后端
万少14 小时前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
尘世中一位迷途小书童16 小时前
用 Cesium 撸了一个森林火情监控大屏,弧线、粒子、发光效果都齐了
前端·javascript
IT_陈寒17 小时前
垃圾回收器选错了,我的Java服务内存炸了
前端·人工智能·后端
月光下的丝瓜17 小时前
Flutter 国内安装指南
前端·flutter
先吃饱再说17 小时前
JavaScript中`this` 的“千层套路”:从默认绑定到箭头函数的五种指向
javascript
玄星啊17 小时前
AI 编程的第 30 天,我怀念古法 Coding 了
前端·ai编程
Jolyne_17 小时前
Angular基础速通
前端·angular.js
foxire18 小时前
基于nodejs实现服务端内核引擎
javascript