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)聽(tīng)子組件向父組件傳參 --> <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ì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08vue實(shí)現(xiàn)GitHub的第三方授權(quán)方法示例
本文主要介紹了vue實(shí)現(xiàn)GitHub的第三方授權(quán),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Element實(shí)現(xiàn)登錄+注冊(cè)的示例代碼
登錄注冊(cè)是最常用的網(wǎng)站功能,本文主要介紹了Element實(shí)現(xiàn)登錄+注冊(cè)的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09vue2.0項(xiàng)目中使用Ueditor富文本編輯器示例代碼
本篇文章主要介紹了vue2.0項(xiàng)目中使用Ueditor富文本編輯器示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08Vue腳手架學(xué)習(xí)之項(xiàng)目創(chuàng)建方式
這篇文章主要給大家介紹了關(guān)于Vue腳手架學(xué)習(xí)之項(xiàng)目創(chuàng)建方式的相關(guān)資料,文中通過(guò)介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03vue路由跳轉(zhuǎn)時(shí)判斷用戶是否登錄功能的實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇vue路由跳轉(zhuǎn)時(shí)判斷用戶是否登錄功能的實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10