加入收藏 | 设为首页 | 会员中心 | 我要投稿 厦门网 (https://www.xiamenwang.cn/)- 数据采集、建站、AI开发硬件、专属主机、云硬盘!
当前位置: 首页 > 教程 > 正文

vue日期设置范围有默认值不生效如何搞定

发布时间:2023-09-01 11:12:09 所属栏目:教程 来源:互联网
导读:   这篇文章主要介绍了vue日期设置范围有默认值不生效如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue日期设置范围有默认值不生效如何解决文章
  这篇文章主要介绍了vue日期设置范围有默认值不生效如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue日期设置范围有默认值不生效如何解决文章都会有所收获,下面我们一起来看看吧。
 
  一、问题描述
 
  在 Vue.js 中,使用日期组件时,可以通过设置 picker-options 中的属性来实现日期范围的限制。例如,可以通过设置 disabledDate 或者 shortcuts 来规定日期范围等限制条件,如下所示:
 
  <el-date-picker
 
      v-model="dateValue"
 
      :picker-options="pickerOptions">
 
  </el-date-picker>
 
  其中,pickerOptions 是一个对象,可以设置 disabledDate、shortcuts 等属性,如下所示:
 
  data () {
 
      return {
 
          pickerOptions: {
 
              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])
 
                      }
 
                  },
 
                  {
 
                      text: '最近三个月',
 
                      onClick (picker) {
 
                          const end = new Date()
 
                          const start = new Date()
 
                          start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
 
                          picker.$emit('pick', [start, end])
 
                      }
 
                  }
 
              ],
 
              disabledDate (time) {
 
                  return time.getTime() < Date.now() - 8.64e7 || time.getTime() > Date.now() + 8.64e7
 
              }
 
          },
 
          dateValue: ''
 
      }
 
  }
 
  上述代码中,shortcuts 和 disabledDate 都是设置日期范围的属性。其中,shortcuts 可以设置三个快捷日期范围,分别为最近一周、最近一个月、最近三个月。而 disabledDate 则是限制日期的取值范围,这里设置的是不能晚于今天或早于昨天。
 
  但是,在实际的开发过程中,可能会发现无论怎么设置,始终无法达到我们想要的效果,这是怎么回事呢?
 
  二、解决方案
 
  针对上述问题,我们需要检查代码中是否有其他设置日期范围的属性或方法,如果有,就需要将这些属性或方法注释或者删除掉,然后再进行测试,看是否可以达到我们想要的效果。
 
  同时,我们还需要注意日期格式的问题。在使用日期组件时,日期格式需要和设置的日期范围格式保持一致,否则也会导致设置日期范围失效的问题。例如,如果日期格式为 'yyyy-MM-dd',则设置的日期范围也应该为 'yyyy-MM-dd'。具体的代码可以参考下方:
 
  data () {
 
      return {
 
          pickerOptions: {
 
              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])
 
                      }
 
                  },
 
                  {
 
                      text: '最近三个月',
 
                      onClick (picker) {
 
                          const end = new Date()
 
                          const start = new Date()
 
                          start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
 
                          picker.$emit('pick', [start, end])
 
                      }
 
                  }
 
              ],
 
              disabledDate (time) {
 
                  const startTime = new Date('2010/1/1').getTime()
 
                  const endTime = new Date().getTime()
 
                  return time.getTime() < startTime || time.getTime() > endTime
 
              },
 
              format: 'yyyy-MM-dd'
 
          },
 
          dateValue: ''
 
      }
 
  }
 
  上述代码中,我们添加了 format 属性来设置日期的格式,同时也设置了日期范围,时间不能早于 2010 年 1 月 1 日,也不能晚于今天。
 

(编辑:厦门网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章