vue element 日期选择器日期限制

最近遇到一个需求, 使用饿了么实现日表限制三个月查询, 年表限制一年查询, 如果不做限制的话, 有可能造成数据量过大的请求。
周表不做限制的原因是饿了么的周表就是一个一周内的范围, 已经做了限制
因为是多页面使用, 所以封装为公共组件的形式, 这样好维护, 也方便一点

  • 日表限制
  • 年表限制

    日表限制

<template>
  <div>
    <el-date-picker
      v-model="datePickDay"
      :picker-options="pickerOptions"
      type="daterange"
      range-separator="至"
      start-placeholder="开始日期"
      end-placeholder="结束日期"
      size='mini'
      value-format="yyyyMMdd"
      @change="datePickChangeDay"/>

  </div>
</template>
<script>
import { dateFormat } from '@/utils/tools'
export default {
  name: 'EcFrontDatePickerMonth',

  data() {
    return {
      // 日期
      datePickDay: [
        // 日期选择器绑定的数据,为一个数组,数组第一个是开始时间,第二个是结束时间,需求是获取前一天的数据
        dateFormat(new Date(new Date().getTime() - 3600 * 1000 * 24), 'yyyyMMdd'),
        dateFormat(new Date(new Date().getTime() - 3600 * 1000 * 24), 'yyyyMMdd')
      ],
      pickDate: '', // 存放getPickDate获取的数据
      pickerOptions: {
        onPick: this.getPickDate,
        disabledDate: this.disabledDate
      },
    }
  },
  mounted() {
    
  },

  methods: {
 // 改变日期触发Change事件,子传父组件特获取到的日期传给父组件
 datePickChangeDay () {
      console.log(this.datePickDay, 'this.datePickDay')
      this.$emit('dateChange', this.datePickDay)
    },
    // 时间选择跨度三个月限制
    getPickDate(pick) {
      // 获取选择后的时间
      this.pickDate = pick
    },
    // 日期禁用方法
    disabledDate(date) {
     // 获取开始时间和结束时间
      const { minDate, maxDate } = this.pickDate
    // 选择后的时间间隔进行计算间隔大于90天后的日期全部 disabled
      if (minDate && !maxDate) {
        const diff = Math.abs(minDate.valueOf() - date.valueOf())
        if (diff > 1000 * 3600 * 24 * 90) {
          return true
        }
      }
    }
  },
}
</script>

<style lang="scss" scoped>
}
</style>

年表限制

需求为可查询一年内的数据, 以月为单位, 也是封装组件

<template>
  <div>
    <el-date-picker
      ref="picker"
      v-model="datePickMonth"
      type="monthrange"
      :picker-options="pickerOptions"
      range-separator="至"
      start-placeholder="开始日期"
      end-placeholder="结束日期"
      size="mini"
      value-format="yyyyMM"
      @change="datePickChange"
    />
  </div>
</template>

<script>
import { dateFormat } from '@/utils/tools'
export default {
  name: 'EcFrontDatePickerMonth',

  data() {
    return {
      // 日期
      datePickMonth: [
        dateFormat(new Date(new Date().getTime() - 3600 * 1000 * 720), 'yyyyMM'),
        dateFormat(new Date(new Date().getTime() - 3600 * 1000 * 720), 'yyyyMM')
      ],
      pickDate: '', // 存放getPickDate获取的数据
      pickerOptions: {
        onPick: this.getPickDate,
        disabledDate: this.disabledDate
      },
    }
  },

  mounted() {
    
  },

  methods: {
    datePickChange () {
      console.log(this.datePickMonth, 'this.datePickMonth')
      this.$emit('dateChange', this.datePickMonth)
    },
    // 时间选择跨度三年限制
    getPickDate(pick) {
      this.pickDate = pick
    },
    disabledDate(date) {
      const { minDate, maxDate } = this.pickDate
      if (minDate && !maxDate) {
        const diff = Math.abs(minDate.valueOf() - date.valueOf())
        if (diff > 1000 * 3600 * 24 * 365) {
          return true
        }
      }
    }
  },
}
</script>

<style lang="scss" scoped>
}
</style>

希望对你有用!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue中的日期选择器可以使用第三方库如Element UI或Vuetify,这些库提供了日期选择器组件。要设置日期选择器的最小范围,你可以使用组件的属性或者方法来实现。 使用Element UI的日期选择器,你可以通过设置`picker-options`属性来指定最小日期范围。示例代码如下: ```html <el-date-picker v-model="date" :picker-options="pickerOptions" ></el-date-picker> ``` ```javascript data() { return { date: '', pickerOptions: { disabledDate(date) { // 设置最小日期范围 return date.getTime() < Date.now() - 8.64e7; // 一天的毫秒数 } } }; } ``` 在上面的示例中,`picker-options`属性包含一个`disabledDate`函数,该函数接收一个`Date`对象作为参数,并返回一个布尔值。如果返回`true`,则表示该日期将被禁用。在这个函数中,我们可以通过比较日期对象的时间戳来设置最小日期范围。 使用Vuetify的日期选择器,你可以使用`min`属性来设置最小日期范围。示例代码如下: ```html <v-date-picker v-model="date" :min="minDate" ></v-date-picker> ``` ```javascript data() { return { date: '', minDate: new Date(new Date().setDate(new Date().getDate() - 1)) // 设置最小日期为前一天 }; } ``` 在上面的示例中,`min`属性接收一个`Date`对象,表示最小日期范围。在这里,我们使用`new Date().setDate(new Date().getDate() - 1)`来获取前一天的日期,并将其赋值给`minDate`变量。 通过设置这些属性或方法,你可以限制日期选择器的最小范围。请根据你使用的具体库和组件来调整代码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值