zoukankan      html  css  js  c++  java
  • Antd——如何自定义月的选择范围

    前言

    小徒弟的一个问题,写了一个简单的demo,因为是月份的选择,所以我们直接使用MonthPicker组件进行改造即可;

    内容

    CodeSandbox

    MonthPickerForRange

    完整代码

    <template>
      <div>
        <a-month-picker
          placeholder="开始日期"
          v-model="startValue"
          :disabled-date="disabledStartDate"
          @openChange="handleStartOpenChange"
        />
        ~
        <a-month-picker
          placeholder="结束日期"
          v-model="endValue"
          :open="endOpen"
          @openChange="handleEndOpenChange"
          :disabled-date="disabledEndDate"
        />
      </div>
    </template>
    <script>
    import moment from "moment";
    export default {
      data() {
        return {
          startValue: null,
          endValue: null,
          endOpen: false,
        };
      },
      watch: {
        startValue(val) {
          console.log("startValue", val);
        },
        endValue(val) {
          console.log("endValue", val);
        },
      },
      methods: {
        moment,
        disabledStartDate(startValue) {
          const endValue = this.endValue;
          // 未来时间不可选择
          if (startValue.year() > moment().year()) {
            return startValue.month() > -1;
          }
    
          // 选择当年且endValue有值
          if (startValue.year() === moment().year() && endValue) {
            return (
              startValue.valueOf() > endValue.valueOf() || startValue.month() >= 10
            );
          }
    
          // 选择当年endValue无值
          if (startValue.year() === moment().year() && !endValue) {
            return startValue.month() >= 10;
          }
    
          if (!startValue || !endValue) {
            return false;
          }
    
          return startValue.valueOf() > endValue.valueOf();
        },
        disabledEndDate(endValue) {
          const startValue = this.startValue;
          // 未来时间不可选择
          if (endValue.year() > moment().year()) {
            return endValue.month() > -1;
          }
    
          // 选择当年startValue有值
          if (endValue.year() === moment().year() && startValue) {
            return (
              startValue.valueOf() >= endValue.valueOf() || endValue.month() >= 10
            );
          }
    
          // 选择当年startValue无值
          if (endValue.year() === moment().year() && !startValue) {
            return endValue.month() >= 10;
          }
    
          if (!startValue || !endValue) {
            return false;
          }
    
          return startValue.valueOf() >= endValue.valueOf();
        },
        handleStartOpenChange(open) {
          if (!open) {
            this.endOpen = true;
          }
        },
        handleEndOpenChange(open) {
          this.endOpen = open;
        },
      },
    };
    </script>
    
    

    效果

    学无止境,谦卑而行.
  • 相关阅读:
    python : 将txt文件中的数据读为numpy数组或列表
    ROS :为IDE配置环境变量
    ROS 教程之 navigation :在 catkin 环境下创建costmap layer plugin
    ROS 教程之 vision : 用各种摄像头获取图像
    ROS 教程之 network:多台计算机之间网络通信(2)
    MS sql 查询动态表名的方法
    把ocx打包成CAB,并签名
    DataSet 转换成List
    C# 反序列化datetime的处理
    PSP软件开发过程管理
  • 原文地址:https://www.cnblogs.com/wangyang0210/p/15112792.html
Copyright © 2011-2022 走看看