基于elementui 封装周选择范围 组件

这篇博客详细介绍了如何在Vue.js应用中创建一个周选择器组件,包括计算当前周数、设置默认值以及处理近n周的快捷选择。通过监听`value1`和`value2`的变化,确保日期范围的正确性,并提供了自定义的日期格式化。此外,还实现了点击预设快捷选项更新日期范围的功能,如近1周、近4周和近12周。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 template部分,这里的value1,value2的值为我们所选周的星期一,为格林尼治时间的格式; date1, date2为周选择器的value对应的日期,date1取当周的星期一(起始日期),date2取当周的星期日(结束日期),weekNum为周数

computed: {
    weekNum() {
      return Math.round((this.value2 - this.value1) / (24 * 60 * 60 * 1000 * 7)) + 1
    },
  },

 data() {
    return {
      value1: null,
      value2: null,
      date1: '',
      date2: '',

      pickerOptions: {
        firstDayOfWeek: 1,
        disabledDate: (time) => this.getDisabledDate(time, 'start'),
        shortcuts: [{
          text: '近1周',
          onClick: (picker) => {
            this.onWeekChange(picker, 1)
          }
        }, {
          text: '近4周',
          onClick: (picker) => {
            this.onWeekChange(picker, 4)
          }
        }, {
          text: '近12周',
          onClick: (picker) => {
            this.onWeekChange(picker, 12)
          }
        }]
      }
    }
  },

created里面来设置一个起始日期,这里将value设为了最近一周的周一,


 created() {
    this.value1 = this.value2 = moment().isoWeekday(-5).toDate()
  },

 

watch: {
   value1() {
      if (!this.value1) return
      if (this.value1 >= this.value2) {   // 保证value2大于value1
        this.value2 = this.value1
      }
      this.date1 = moment(this.value1.getTime() - 24 * 60 * 60 * 1000).format('YYYY-MM-DD')
      this.onValueChange()   // 这里为我们希望value改变时触发的方法
    },
    value2() {
      if (!this.value2) return
      this.date2 = moment(this.value2.getTime() + 5 * 24 * 60 * 60 * 1000).format('YYYY-MM-DD')
      this.onValueChange()
    },

}

methods: {
    onWeekChange(picker, k) { // 选中近k周后触发的操作
      this.value1 = moment().isoWeekday(-(5 + (k - 1) * 7)).toDate()
      this.value2 = moment().isoWeekday(-5).toDate()  //value2与k值无关,因为它总是为最近一周的周一
      this.$forceUpdate()   // 这里如果不强制更新视图,会出现value值改变而视图中的第几周和日期无变化的情况
    },
}
 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值