ElementUI 年份范围选择器 el-year-picker

效果图

在这里插入图片描述

代码


<!--
*@el-year-picker
*@author yuge
*@date 2023/4/28 14:37
-->
<template>
  <div class="year-range-picker">
    <el-date-picker
      v-model="dateList[0]"
      type="year"
      placeholder="选择开始年"
      :size="size"
      class="year-picker"
      format="yyyy"
      :value-format="valueFormat"
      :picker-options="startDatePicker"
    >
    </el-date-picker>
    <span class="range-word"></span>
    <el-date-picker
      v-model="dateList[1]"
      type="year"
      placeholder="选择结束年"
      :size="size"
      class="year-picker"
      :value-format="valueFormat" 
      :picker-options="endDatePicker"
    >
    </el-date-picker>
  </div>
</template>


<script>
export default {
      
      
  name: "el-year-picker",
  // 接收父组件传入的数据
  props: {
      
      
    value: {
      
      
      // type: Array,
      required: true,
    },
    size: {
      
      
      type: String, default: 'mini'
    },
    valueFormat: {
      
      
      type: String, default: 'yyyy'
    },
  },
  data() {
      
      
    return {
      
      
      dateList: [],
      startDatePicker: this.beginDate(),
      endDatePicker: this.processDate(),
    };
  },
  watch: {
      
      
    value(v) {
      
      
      this.dateList = v || []
    },
    dateList(v) {
      
      
      this.$emit('input', v)
    }
  },
  mounted() {
      
      
  },
  methods: {
      
      
    // 选择年份范围选择时开始时间不能大于结束时间,结束时间不能小于开始时间

    // 提出开始时间必须小于提出结束时间
    beginDate() {
      
      
      let self = this
      return {
      
      
        disabledDate(time) {
      
      
          if (self.dateList[1] !== '') {
      
      
            let fixedTime = new Date(time)
            return fixedTime.getFullYear() > self.dateList[1]
          }
        }
      }
    },
    // 提出结束时间必须大于提出开始时间
    processDate() {
      
      
      let self = this
      return {
      
      
        disabledDate(time) {
      
      
          // let fixedTime = new Date(self.oldTime).getTime()
          // return time.getTime() < fixedTime
          let fixedTime = new Date(time)
          return fixedTime.getFullYear() < self.dateList[0]
        }
      }
    },

  },
};
</script>


<style scoped>
.year-range-picker {
      
      
  color: black;
  text-align: center;
  border: 1px solid #dcdfe6;
  border-radius:4px;
  line-height: 25px;
  overflow: hidden;
  display: flex;
  margin: 4px 0;
}

>>> .el-input__inner{
      
      
  border: 0;
  /*padding: 0;*/
  line-height: 28px;
  height: 28px;
  margin:0;
}

.range-word {
      
      
  margin-left: 10px;
  margin-right: 10px;
  font-size: 12px;
}

.year-range-picker .year-picker {
      
      
  max-width: 150px;
  margin:0;
}
</style>


使用

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/TY_GYY/article/details/130600932