【Ionic】Ionic自动计算时间+时间验证(Datatime,readonly,toFixed,parse)

一、起因

因为要做一个请假,满足一下要求:
1、结束时间不能小于开始时间;
2、开始时间和结束时间可以调到过去的时间,考虑到补假;
3、如果请假天数小于0,则不让提交;
4、请假天数不允许编辑,是自动计算的;

二、解决办法

1、初始化(源代码)

  constructor(private navCtrl:NavController,
              private navParams:NavParams,
              private viewCtrl:ViewController,
              public alertCtrl:AlertController,
              private appService:AppService,
              private toastCtrl: ToastController,
              private leaveService: LeaveService,
              private loadingCtrl:LoadingController){
      this.newLeave.dateStart=new Date(new Date().getTime()+8*60*60*1000).toISOString();//计划请假从
      this.newLeave.dateEnd=new Date(new Date().getTime()+8*60*60*1000).toISOString();//计划请假至
      this.newLeave.sqsj=new Date(new Date().getTime()+8*60*60*1000).toISOString();//申请时间
      this.newLeave.leaveKinds='事假';
      this.newLeave.qjts=(Date.parse(this.newLeave.dateEnd)-Date.parse(this.newLeave.dateStart))/(1000*60+60*24)
  }

2、截图

这里写图片描述

3、说明

3.1、时间类后面加了一个8*60*60*10000 这个是8小时的时区时差,我们东八区的时间比国际时间少了8个小时,要补上;
3.2、toISOString():是Ionic插件<ion-datetime></ion-datetime> 默认的显示时间格式;
3.3 Date.parse()方法是将ISOString类型的时间变成Date类型的时间;

4、时间验证

这里在开始时间和结束时间那里都加了一个时间变化验证:
4.1、html:
这里写图片描述

这里,请假天数是不允许编辑的,用了一个readonly=”true”属性;

4.2、TS逻辑:
这里写图片描述

这里用了一个toFixed()方法,四舍五入,保留1位小数;因为允许半天假,小时假;

欢迎关注我的公众号:
【幕桥社区】
这里写图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

陶洲川

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

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

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

打赏作者

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

抵扣说明:

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

余额充值