vue3+elementPlus實(shí)現(xiàn)年份選擇器
下面是vue3結(jié)合elementPlus實(shí)現(xiàn)簡(jiǎn)單年份選擇器的示例代碼,希望對(duì)大家有所幫助
1.組件
<template>
<div class="year-range-picker">
<el-date-picker
v-model="startYear"
type="year"
:placeholder="config['archivesCenter:archiveList:startYear']"
size="mini"
class="year-picker"
style=" max-width: 150px !important;"
@change="changeStartYear"
format="YYYY"
value-format="YYYY"
>
</el-date-picker>
<span class="range-word"> {{config['archivesCenter:archiveList:to']}} </span>
<el-date-picker
v-model="endYear"
type="year"
:placeholder="config['archivesCenter:archiveList:endYeare']"
size="mini"
class="year-picker"
style=" max-width: 150px !important;"
@change="changeEndYear"
format="YYYY"
value-format="YYYY"
>
</el-date-picker>
</div>
</template>
<script setup lang="ts">
//導(dǎo)入多語(yǔ)言配置
import {languageData} from '~/stores/global'
import { ElMessage } from 'element-plus'
const config:any = computed(() => languageData().languageConfig.config);
interface IProps {
yearRange:Array
}
const props = withDefaults(defineProps<IProps>(), {
yearRange:[]
})
//綁定年份
const startYear =ref("")
const endYear =ref("")
const emits =defineEmits(['yearChanged'])
watchEffect(()=>{
startYear.value = String(props.yearRange[0]);
endYear.value = String(props.yearRange[1]);
})
const changeStartYear=(val) =>{
if (Number(val)&&Number(endYear.value)&&(Number(startYear.value) > Number(endYear.value))) {
startYear.value = ''
return ElMessage.error(config.value['archivesCenter:archiveList:timeTip'])
}
if (val) {
startYear.value = val;
}
let times=[Number(startYear.value) || '', Number(endYear.value) || '']
// 將改動(dòng)傳回父組件
emits("yearChanged", times);
}
const changeEndYear=(val) =>{
if (Number(val)&&Number(startYear.value)&&(Number(startYear.value) > Number(endYear.value))) {
endYear.value = ''
return ElMessage.error(config.value['archivesCenter:archiveList:timeTip'])
}
if (val) {
endYear.value = val;
}
let times=[Number(startYear.value) || '', Number(endYear.value) || '']
emits("yearChanged", times)
}
</script>
<style scoped lang="less">
.year-range-picker {
color: black;
text-align: center;
font-size: 18px;
}
.range-word {
margin-left: 10px;
margin-right: 10px;
}
.year-picker {
max-width: 100px !important;
}
</style>2.組件使用
<!-- :yearRange 為父組件向子組件傳參 -->
<!-- :key 保證父組件的數(shù)據(jù)更新后,重新渲染子組件,使子組件也同步更新 -->
<!-- @yearChanged 監(jiān)聽子組件向父組件傳參 -->
<yearRangePicker
:yearRange="yearRange"
:key="`${yearRange[0]}_${yearRange[1]}`"
@yearChanged="handleYearChanged"
>
</yearRangePicker>`到此這篇關(guān)于vue3+elementPlus實(shí)現(xiàn)年份選擇器的文章就介紹到這了,更多相關(guān)vue3年份選擇器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue異步axios獲取的數(shù)據(jù)渲染到頁(yè)面的方法
今天小編就為大家分享一篇vue異步axios獲取的數(shù)據(jù)渲染到頁(yè)面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例
本文主要介紹了vue實(shí)現(xiàn)GitHub的第三方授權(quán),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
Element實(shí)現(xiàn)登錄+注冊(cè)的示例代碼
登錄注冊(cè)是最常用的網(wǎng)站功能,本文主要介紹了Element實(shí)現(xiàn)登錄+注冊(cè)的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
vue2.0項(xiàng)目中使用Ueditor富文本編輯器示例代碼
本篇文章主要介紹了vue2.0項(xiàng)目中使用Ueditor富文本編輯器示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
Vue腳手架學(xué)習(xí)之項(xiàng)目創(chuàng)建方式
這篇文章主要給大家介紹了關(guān)于Vue腳手架學(xué)習(xí)之項(xiàng)目創(chuàng)建方式的相關(guān)資料,文中通過介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
vue路由跳轉(zhuǎn)時(shí)判斷用戶是否登錄功能的實(shí)現(xiàn)
下面小編就為大家?guī)硪黄獀ue路由跳轉(zhuǎn)時(shí)判斷用戶是否登錄功能的實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10

