vue3+element-plus el-date-picker日期组件再次封装(DatePicker与DateTimePicker合并根据type值来显示并自定义常规快捷方式)




<template>
  <el-date-picker
    v-model="dateValue"
    :type="type"
    :placeholder="placeholder"
    :disabled="disabled"
    :clearable="clearable"
    :editable="editable"
    :size="size"
    :align="align"
    :popper-class="popperClass"
    :picker-options="pickerOptions"
    :default-value="defaultValue"
    :default-time="defaultTime"
    :value-format="valueFormat"
    :format="format"
    :style="style"
    @change="handleChange"
  ></el-date-picker>
</template>
 
<script setup>
import { ref, watch } from 'vue';
import { ElDatePicker } from 'element-plus';
 
const props = defineProps({
  modelValue: {
    type: [String, Date, Array],
    default: ''
  },
  type: {
    type: String,
    default: 'date' // date, datetime, datetimerange, daterange, month, year
  },
  placeholder: {
    type: String,
    default: ''
  },
  disabled: {
    type: Boolean,
    default: false
  },
  clearable: {
    type: Boolean,
    default: true
  },
  editable: {
    type: Boolean,
    default: true
  },
  size: {
    type: String,
    default: 'small' // large, small
  },
  align: {
    type: String,
    default: 'left' // left, center, right
  },
  popperClass: {
    type: String,
    default: ''
  },
  pickerOptions: {
    type: Object,
    default: () => ({})
  },
  defaultValue: {
    type: Date,
    default: null
  },
  defaultTime: {
    type: String,
    default: '00:00:00'
  },
  valueFormat: {
    type: String,
    default: 'yyyy-MM-dd HH:mm:ss' // 例如:yyyy-MM-dd HH:mm:ss
  },
  format: {
    type: String,
    default: 'yyyy-MM-dd HH:mm:ss' // 例如:yyyy-MM-dd HH:mm:ss
  },
  style: {
    type: String,
    default: ''
  }
});
 
const emit = defineEmits(['update:modelValue', 'change']);
 
const dateValue = ref(props.modelValue);
 
watch(dateValue, (newValue) => {
  emit('update:modelValue', newValue);
});
 
const handleChange = (value, date) => {
  emit('change', value, date);
};
</script>

这个示例中,我们创建了一个Vue 3组件,它封装了Element Plus的<el-date-picker>组件。我们使用了Composition API(setup函数),以及refwatch来管理组件的状态。我们提供了一系列的props来配置日期选择器,并且能够通过update:modelValue事件和change事件与父组件通信。这个封装的组件可以用于日期选择场景,并且可以方便地进行配置和扩展。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日