elementUI+el-date-picker实现“季度”功能

1、效果图

2、代码

        季度组件↓

<template>
  <!-- 季度选择时间控件 -->
  <div class="season">
    <span>
      <mark
        style="position:fixed;top:0;bottom:0;left:0;right:0;background:rgba(0,0,0,0);z-index:999;"
        v-show="showSeason"
        @click.stop="showSeason=false"
      ></mark>
      <el-input
        placeholder="选择季度"
        v-model="showValue"
        style="width:224px;"
        @focus="showSeason=true"
      >
        <i slot="prefix" class="el-input__icon el-icon-date"></i>
      </el-input>
      <el-card
        class="box-card"
        style="width:322px;padding: 0 3px 20px;margin-top:10px;position:fixed;z-index:9999"
        v-show="showSeason"
      >
        <div slot="header" class="firstBtn">
          <button
            type="button"
            aria-label="前一年"
            class="el-picker-panel__icon-btn el-date-picker__prev-btn el-icon-d-arrow-left"
            @click="prev"
          ></button>
          <span role="button" class="el-date-picker__header-label">{{year}}年</span>
          <button
            type="button"
            aria-label="后一年"
            @click="next"
            class="el-picker-panel__icon-btn el-date-picker__next-btn el-icon-d-arrow-right"
          ></button>
        </div>
        <div class="text container">
          <!-- 如下,绑定class,disabled为禁止选择的时间的设置 -->
          <!--  :disabled="this.year === this.beforeyear && this.season <= 1 || this.year > this.defaultyear" -->
          <el-button
            type="text"
            size="medium"
            style="width:47%;float:left;"
            @click="selectSeason(0)"
          >第一季度</el-button>
          <!-- :disabled="this.year === this.beforeyear && this.season <= 2 || this.year > this.defaultyear" -->
          <el-button
            type="text"
            size="medium"
            style="float:right;width:47%;"
            @click="selectSeason(1)"
          >第二季度</el-button>
        </div>
        <div class="item container" style="text-align:center;">
          <!-- :disabled="this.year === this.beforeyear && this.season <= 3 || this.year > this.defaultyear" -->
          <el-button
            type="text"
            size="medium"
            style="width:47%;float:left;"
            @click="selectSeason(2)"
          >第三季度</el-button>
          <!-- :disabled="this.year === this.beforeyear && this.season <= 4 || this.year > this.defaultyear" -->
          <el-button
            type="text"
            size="medium"
            style="float:right;width:47%;"
            @click="selectSeason(3)"
          >第四季度</el-button>
        </div>
      </el-card>
    </span>
  </div>
</template>
 
<script>
/**
 * @file:  View 组件 季节选择控件
 * @description: UI组件  可选择季节
 * @api: valueArr : 季度value defalut['01-03', '04-06', '07-09', '10-12'] 默认值待设置
 * 代码中注释部分是组件原默认时间配置,我这里做了更改,但是原设置可以参考
 */
export default {
  name: "jududatepicker",
  props: {
    valueArr: {
      default: () => {
        return ["01-03", "04-06", "07-09", "10-12"];
      },
      type: Array
    },
    getValue: {
      default: val => {
        return val;
      },
      type: Function
    }
  },
  data() {
    return {
      showSeason: false,
      season: "",
      year: new Date().getFullYear(), // input显示时间,会随着用户操作改变
      defaultyear: new Date().getFullYear(), // 当前年份,不变
      month: new Date().getMonth() + 1, // 当前月份,不变
      showValue: "",
      beforeyear: null // 默认显示上一季度所用时间,可能是去年
    };
  },
  mounted() {
    // 每次挂在时都对组件进行重置,那么就不需要在上级组件中进行重置
    this.getDefaultTime();
  },
  methods: {
    one() {
      this.showSeason = false;
    },
    prev() {
      this.year = this.year * 1 - 1;
    },
    next() {
      this.year = this.year * 1 + 1;
    },
    selectSeason(i) {
      let that = this;
      that.season = i + 1;
      let arr = that.valueArr[i].split("-");
      let seasonValue = that.getValue(that.year + "-" + arr[0] + "-" + "01");
      that.showSeason = false;
      this.showValue = `${this.year} 年 ${this.season} 季度`;
      that.$emit("chooseSeason", seasonValue); // 每次选择时间都将当前选择时间发送到父组件
    },
    reset() {
      // 季度重置 上一季度
      this.getDefaultTime();
    },
    getDefaultTime() {
      // 获取默认的上一个季度
      var year = this.defaultyear;
      var month = this.month;
      var season = null;
      if (month <= 3) {
        this.season = 1;
        year -= 1;
        season = 4;
        this.beforeyear = year;
      } else if (month > 3 && month <= 6) {
        this.season = 2;
        season = 1;
        this.beforeyear = year;
      } else if (month > 6 && month <= 9) {
        this.season = 3;
        season = 2;
        this.beforeyear = year;
      } else if (month > 9 && month <= 12) {
        this.season = 4;
        season = 3;
        this.beforeyear = year;
      }
      this.showValue = `${year} 年 ${season} 季度`;
    }
  }
};
</script>
 
<style lang="less" scoped>
.season {
  display: inline;
  .firstBtn {
    height: 30px;
    line-height: 34px;
    width: 100%;
    text-align: center;
  }
  .text {
    text-align: center;
    margin: 15px 0 10px;
  }
  .item {
    text-align: center;
  }
  /deep/.el-button--text{
    color:#666 !important;
  }
  /deep/.el-button--text:active, .el-button--text:hover {
    color: #006ee6 !important;
  }
}
.colorDis {
  color: #999 !important;
}
</style>
<style lang="less">
.season {
  .el-card__header {
    padding: 12px;
  }
}

</style>

   引用↓

import season from './season'
*
*
*
*
*
*
*
*
components: {
  season
}
*
*
*
*
*
*
*
*
<season ref="season" @chooseSeason="seasonChange"/>
*
*
*
*
*
*
*
*
seasonChange(val) {
  console.log("季",val);
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
el-date-pickerElement UI中的日期选择器组件,picker-options是el-date-picker组件的一个属性,用于配置日期选择器的选项。 通过设置picker-options属性,可以自定义日期选择器的行为和外观。常见的picker-options属性包括: 1. disabledDate:用于禁用某些日期的函数。可以根据具体需求自定义禁用的日期范围。 2. shortcuts:用于配置快捷选项的数组。每个快捷选项都是一个对象,包含text和onClick两个属性。text表示快捷选项的文本,onClick是一个回调函数,用于处理点击快捷选项后的逻辑。 3. format:用于指定日期的显示格式。可以使用预定义的格式字符串,也可以自定义格式。 4. placeholder:用于设置日期选择器的占位符文本。 5. startPlaceholder和endPlaceholder:用于设置范围选择器的开始和结束日期的占位符文本。 6. rangeSeparator:用于设置范围选择器的分隔符文本。 下面是一个示例,演示如何使用picker-options属性配置el-date-picker组件: ```html <template> <div> <el-date-picker v-model="date" type="date" :picker-options="pickerOptions" placeholder="选择日期" ></el-date-picker> </div> </template> <script> export default { data() { return { date: '', pickerOptions: { disabledDate(time) { // 禁用所有今天之前的日期 return time.getTime() < Date.now() - 8.64e7; }, shortcuts: [ { text: '最近一周', onClick(picker) { const end = new Date(); const start = new Date(); start.setTime(start.getTime() - 3600 * 1000 * 24 * 7); picker.$emit('pick', [start, end]); } }, { text: '最近一个月', onClick(picker) { const end = new Date(); const start = new Date(); start.setTime(start.getTime() - 3600 * 1000 * 24 * 30); picker.$emit('pick', [start, end]); } } ], format: 'yyyy-MM-dd', placeholder: '请选择日期' } }; } }; </script> ``` 在上面的示例中,pickerOptions对象包含了disabledDate、shortcuts、format和placeholder等属性,用于配置日期选择器的选项。通过设置picker-options属性,可以实现禁用过去日期、添加快捷选项、指定日期格式和设置占位符文本等功能

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值