ElementPlus 自定義封裝 el-date-picker 的快捷功能示例詳解
更新時間:2024年12月30日 09:35:15 作者:博客zhu虎康
文章討論了用戶對官網(wǎng)提供的案例不滿足快捷功能需求的情況,建議在外部自定義組件中導入并使用快捷內(nèi)容,以滿足用戶需求,本文通過實例代碼給大家介紹的非常詳細,感興趣的朋友一起看看吧
需求

分析
我們看到官網(wǎng)上給出的案例如下,但是不太滿足我們用戶想要的快捷功能,因為不太多,因此需要我們自己封裝一些,方法如下

外部自定義該組件的快捷內(nèi)容
export const getPickerOptions = () => {
const shortcuts = [
{
text: '過去1小時',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 1);
return [start, end]
},
},
{
text: '過去4小時',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 4);
return [start, end]
},
},
{
text: '過去12小時',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 12);
return [start, end]
},
},
{
text: '昨天到今天',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24);
return [start, end]
},
},
{
text: '最近一周',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
return [start, end]
},
},
{
text: '最近一個月',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
return [start, end]
},
},
{
text: '最近三個月',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
return [start, end]
},
},
{
text: '過去半年',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 183);
return [start, end]
},
},
{
text: '過去3年',
value: () => {
const end = new Date()
const start = new Date()
start.setTime(start.getTime() - 3600 * 1000 * 24 * 365 * 3);
return [start, end]
},
},
]
return shortcuts
};組件中導入并使用
<template>
<el-date-picker
v-model="editForm_tree.time"
type="datetimerange"
show-time
value-format="YYYY-MM-DD HH:mm:ss"
:shortcuts="shortcuts"
range-separator="到"
start-placeholder="開始時間"
end-placeholder="結(jié)束時間"
/>
</template>
<script lang="ts" setup>
import {
onBeforeUnmount,
onMounted,
ref,
watch,
watchEffect,
computed,
reactive,
} from 'vue';
import { getPickerOptions } from '@/utils/pickerOptions.js';
const shortcuts = getPickerOptions();
</script>到此這篇關于ElementPlus 自定義封裝 el-date-picker 的快捷功能示例詳解的文章就介紹到這了,更多相關ElementPlus 自定義封裝 el-date-picker內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring Boot/VUE中路由傳遞參數(shù)的實現(xiàn)代碼
在路由時傳遞參數(shù),一般有兩種形式,一種是拼接在url地址中,另一種是查詢參數(shù)。這篇文章主要介紹了Spring Boot/VUE中路由傳遞參數(shù),需要的朋友可以參考下2018-03-03
vuex中數(shù)據(jù)持久化插件vuex-persistedstate使用詳解
這篇文章主要介紹了vuex中數(shù)據(jù)持久化插件vuex-persistedstate使用詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03

