elment ui 时间组件(el-date-picker)限制只能选择当前时间之后的时间(包括时分秒的限制)

方法一、只能限制日期和小时的方法

实现的方式:
option实现插件只能选取当前时间之后的时候(包括年月日)
handle实现插件能选取当前时间的时、分、秒,但是选择完毕之后,只要选择的时、分、秒小于当前时间,会自动填充为当前的时、分、秒

如图当前是2020-05-13 17:00;
年月日不能选取小于当前时间的,但是时分能选,但是点了ok之后,如果时间小于当前时间,会自动替换成当前时间

在这里插入图片描述

html:  

<el-date-picker
        v-model="nowTime"
        type="datetime"
        format="yyyy-MM-dd HH:mm:ss"
        start=""
        :picker-options="option"
        @change="handle"
        placeholder>
</el-date-picker>

js:

<script>
import {nowTime} from '../../utils/times'
export default {
  data() {
    return {
        nowTime: nowTime(),
        option:{
            disabledDate(time){
                return time.getTime() < Date.now()-1 * 24 * 3600 * 1000
            },
            selectableRange: new Date(new Date().setHours(new Date().getHours()+1                 
               )).format('hh') + ':00:00 - 23:59:59'

        }
    }
  },
  mounted() {
    console.log("nowTime:", this.nowTime);
  },
  methods: {
    handle() {
       var startAt = new Date(this.nowTime) * 1000 /1000;
        if(startAt < Date.now()) {
            this.nowTime = new Date();
        }
    },
  }
};
</script>

获取nowTime  当前本机电脑时间的插件times.js: 2020-10-21 15:24:55

times.js:

export function FromDates() {
    const timeStamp = new Date()
    let year = (new Date(timeStamp).getFullYear()).toString()
    let month = (new Date(timeStamp).getMonth() + 1 < 10 ? '0' + (new Date(timeStamp).getMonth() + 1) : new Date(timeStamp).getMonth() + 1).toString()
    let date = (new Date(timeStamp).getDate() < 10 ? '0' + new Date(timeStamp).getDate() : new Date(timeStamp).getDate()).toString()
    let hh = (new Date(timeStamp).getHours() < 10 ? '0' + new Date(timeStamp).getHours() : new Date(timeStamp).getHours()).toString()
    let mm = (new Date(timeStamp).getMinutes() < 10 ? '0' + new Date(timeStamp).getMinutes() : new Date(timeStamp).getMinutes()).toString()
    let ss = (new Date(timeStamp).getSeconds() < 10 ? '0' + new Date(timeStamp).getSeconds() : new Date(timeStamp).getSeconds()).toString()
    let nowTime = year + month + date + hh + mm + ss
    return nowTime
  }
  
  export function FromTimes(timeStamp) { // 时间转换
    let year = new Date(timeStamp).getFullYear()
    let month = new Date(timeStamp).getMonth() + 1 < 10 ? '0' + (new Date(timeStamp).getMonth() + 1) : new Date(timeStamp).getMonth() + 1
    let date = new Date(timeStamp).getDate() < 10 ? '0' + new Date(timeStamp).getDate() : new Date(timeStamp).getDate()
    let hh = new Date(timeStamp).getHours() < 10 ? '0' + new Date(timeStamp).getHours() : new Date(timeStamp).getHours()
    let mm = new Date(timeStamp).getMinutes() < 10 ? '0' + new Date(timeStamp).getMinutes() : new Date(timeStamp).getMinutes()
    let ss = new Date(timeStamp).getSeconds() 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT博客技术分享

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值