使用element UI的日期选择器,默认显示当天日期及7天前日期

本文对比了Vue中两种日期选择器的实现方式,一种使用timestamp格式获取时间戳,另一种以yyyy-MM-dd格式显示日期。通过实例展示了如何设置默认值和方法获取当前日期范围。

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

方法一 (  采用选择器 type= datetimerange 默认获取内容为时间戳 )

<template>
  <div class="machineApp">
    <el-date-picker
      v-model="formInline.value1"
      type="datetimerange"
      range-separator="至"
      start-placeholder="开始日期"
      end-placeholder="结束日期"
      value-format="timestamp"
    />
  </div>
</template>

<script>
export default {
  data() {
    return {
      formInline: {
        value1: this.getDateTime() //methods优先级高于data  (props==>methods==>data==>computed==>watch)
      }
    }
  },
  methods: {
    getDateTime() {
      return [new Date(new Date().getTime() - 3600 * 1000 * 24 * 7).getTime(), new Date().getTime()]
    }
  }
}
</script>

方法二 (  采用选择器 type= daterange 默认获取内容为  yyyy-MM-dd hh:mm:ss 例如:2022-07-18 07:59:29 )

<template>
  <div class="machineApp">
    <el-form :inline="true"
             :model="formInline"
             class="demo-form-inline">
      <el-form-item label="审批人">
        <el-date-picker v-model="formInline.value1"
                        type="daterange"
                        range-separator="至"
                        start-placeholder="开始日期"
                        end-placeholder="结束日期">
        </el-date-picker>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
  data() {
    return {
      formInline: {
        value1: []
      }
    }
  },
  created() {
    this.formInline.value1 = this.getNowTime()
  },
  methods: {
    //初始默认执行(重点)
    getNowTime() {
      const start = new Date(new Date().getTime() - 3600 * 1000 * 24 * 7)
        .toISOString()
        .replace('T', ' ')
        .split('.')[0] //默认开始时间7天前
      const end = new Date(new Date().getTime() - 3600 * 1000 * 24)
        .toISOString()
        .replace('T', ' ')
        .split('.')[0]//默认结束时间1天前
      console.log([start, end])
      return [start, end]
    }
  }
}
</script>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值