vue3+elementPlus实现年份选择器

 更新时间:2024年01月10日 10:24:53   作者:乐了个乐  
这篇文章主要为大家详细介绍了vue3如何通过elementPlus实现一个简单的年份选择器,文中的示例代码讲解详细,需要的小伙伴可以跟随小编一起学习一下

下面是vue3结合elementPlus实现简单年份选择器的示例代码,希望对大家有所帮助

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">
//导入多语言配置
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) || '']
 
      // 将改动传回父组件
      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 保证父组件的数据更新后,重新渲染子组件,使子组件也同步更新 -->
    <!-- @yearChanged 监听子组件向父组件传参 -->
           <yearRangePicker
            :yearRange="yearRange"
            :key="`${yearRange[0]}_${yearRange[1]}`"
            @yearChanged="handleYearChanged"
                  >
          </yearRangePicker>`

到此这篇关于vue3+elementPlus实现年份选择器的文章就介绍到这了,更多相关vue3年份选择器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用mint-ui开发项目的一些心得(分享)

    使用mint-ui开发项目的一些心得(分享)

    下面小编就为大家带来一篇使用mint-ui开发项目的一些心得(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • vue中的mvvm模式讲解

    vue中的mvvm模式讲解

    今天小编就为大家分享一篇关于vue中的mvvm模式讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 基于vue实现swipe分页组件实例

    基于vue实现swipe分页组件实例

    本篇文章主要介绍了基于vue实现swipe分页组件实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • element ui el-date-picker组件默认值方式

    element ui el-date-picker组件默认值方式

    这篇文章主要介绍了element ui el-date-picker组件默认值方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • vue2中使用echarts实现中国地图、在中国地图上标注坐标散点图的操作代码

    vue2中使用echarts实现中国地图、在中国地图上标注坐标散点图的操作代码

    这篇文章主要介绍了vue2中使用echarts实现中国地图、在中国地图上标注坐标散点图,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )

    Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK )

    这篇文章主要介绍了Vue服务端渲染和Vue浏览器端渲染的性能对比(实例PK ),非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • vite环境变量.env文件的配置及使用

    vite环境变量.env文件的配置及使用

    在Vite中,我们可以使用环境变量来管理不同环境下的配置,本文主要介绍了vite环境变量.env文件的配置及使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • vue3 element-plus el-tree自定义图标方式

    vue3 element-plus el-tree自定义图标方式

    这篇文章主要介绍了vue3 element-plus el-tree自定义图标方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • vue3 pinia使用及持久化注册

    vue3 pinia使用及持久化注册

    本文介绍了Pinia的使用方法及如何实现状态持久化存储,首先,介绍了Pinia的安装和在main.ts中的挂载,介绍了getters和actions的使用方法,最后,详细说明了如何通过Pinia-plugin-persistedstate插件实现Pinia状态的持久化处理,包括插件的安装、配置和在main.ts文件中的注册
    2024-10-10
  • Vue+webpack项目基础配置教程

    Vue+webpack项目基础配置教程

    这篇文章主要介绍了Vue+webpack项目基础配置教程,需要的朋友可以参考下
    2018-02-02

最新评论