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>
相关推荐
颜酱1 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
失忆爆表症2 小时前
05_UI 组件库集成指南:Shadcn/ui + Tailwind CSS v4
前端·css·ui
小迷糊的学习记录2 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜2 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试
不爱吃糖的程序媛2 小时前
Flutter 与 OpenHarmony 通信:Flutter Channel 使用指南
前端·javascript·flutter
利刃大大2 小时前
【Vue】Element-Plus快速入门 && Form && Card && Table && Tree && Dialog && Menu
前端·javascript·vue.js·element-plus
NEXT063 小时前
AI 应用工程化实战:使用 LangChain.js 编排 DeepSeek 复杂工作流
前端·javascript·langchain
念风零壹3 小时前
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
前端·ai
光影少年3 小时前
react的hooks防抖和节流是怎样做的
前端·javascript·react.js
小毛驴8503 小时前
Vue 路由示例
前端·javascript·vue.js