【Ionic】ion-datetime设置初始时间为当前时间及知识点总结;

一、问题描述

我在做手机App的时候,用到了ion-datatime插件,但是该插件不能显示当前时间,只是一个空白;

  <ion-item>
            <ion-label>申请时间</ion-label>
            <ion-datetime name="sqsj" displayFormat="YYYY/MM/DD HH:mm" [(ngModel)]="newLeave.sqsj" >
            </ion-datetime>
        </ion-item>

截图:
这里写图片描述

二、解决办法

在ts或者js里面的构造器contructor里面新建一个当前时间初始值即可;

    constructor(private navCtrl:NavController,
                 private navParams:NavParams,
                public alertCtrl:AlertController,
                private toastCtrl: ToastController,
                private leaveService: LeaveService,
                private loadingCtrl:LoadingController){
      //原来方法:this.newLeave.dateStart=new Date().toISOString();会误差8个小时,以下方法是个简单处理技巧,仅限中国地区使用
    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();//申请时间
    }

感谢純屬遊戲的评论;没有考虑到ISO时间比我们中国当地时间(即东八区)相差8个小时,后来更新上面的代码和下面的图片,更新后,可能全文的代码和图片不能串一起,不是一个完整的例子,而是割裂的例子,阅读起来有点别扭,见谅;

这里写图片描述
这样,每一个时间都有一个初始值;

三、知识点总结

<ion-item>
  <ion-label>申请时间</ion-label>
  <ion-datetime name="sqsj" displayFormat="YYYY/MM/DD HH:mm" [(ngModel)]="newLeave.sqsj" cancelText="取消" doneText="确认">
  </ion-datetime>
</ion-item>

1、displayFormat
表示显示时间的格式,你可以自己定义,用斜杠或者其他符号都可以;

2、[(ngModel)]
表示绑定的模型;你可以绑定你js或ts里面的属性,也可以绑实体类;我这里绑定的是newLeave实体的具体成员变量sqsj(申请时间);但是,我在ts中只声明了newLeave,没有声明这个成员变量;下面的this.newLeave.sqsj=new Date()里面应该修改为:

this.newLeave.sqsj=new Date(new Date().getTime()+8*60*60*1000).toISOString();

不要看错了!!!!!
这里写图片描述
但是Ionic也认;就是说[(ngModel)]=”newLeave.sqsj”表示把我这里的时间的值赋值给newLeave.sqsj;

3、cancelText=”取消” doneText=”确认”
表示打开插件之后,取消和确认是原来默认的英文,还是显示为中文“取消”和“确认”字样;如果不写这两句,默认是英文的:
这里写图片描述

添加cancelText=”取消” doneText=”确认”之后:
这里写图片描述

4、时间格式规则
这里,需要什么格式的,就按照例子写就可以了;
这里写图片描述

5、日期和时间
在中文里,时间和日期是很模糊的概念;时间是非常广义的意思;而日期相对来说就要小一些,表示年月日的叫日期;但是,在英文里,年月日叫Date,小时和分钟,秒叫Time;这里,我们也约定一下,并且推广一下,Date是年月日,Time是时分秒;
这里写图片描述

6、pickerFormat选择器里面的时间格式

 <ion-item>
   <ion-label>申请时间</ion-label>
   <ion-datetime name="sqsj" displayFormat="YYYY/MM/DD HH:mm" pickerFormat="YYYY-MMMM-DD HH:mm" [(ngModel)]="newLeave.sqsj" >
   </ion-datetime>
</ion-item>

这里我们选择的pickerFormat格式是“YYYY-MMMM-DD HH:mm”;注意,这里起作用的不是短横,而是MMMM,这里是英文全称,比如一月是Nov…,而不是11;
这里写图片描述
我们来对比下pickerFormat格式是“YYYY-MM-DD HH:mm”的:
这里写图片描述;
对比很明显了,这里我们就知道pickerFormat的作用了,作用规则根据上面的规则例子表来参照;

### 使用 `ion-datetime-button` 组件 #### 显示和选择日期时间 为了提供更便捷的方式让用户打开 DateTime 拣选器,Ionic 提供了 `ion-datetime-button` 组件。此按钮组件专门设计来触发 DateTime 拣选器对话框,允许用户通过点击按钮而非直接交互 DateTime 控件本身来进行日期时间和的选择[^2]。 下面是一个简单的例子展示如何使用 `ion-datetime-button` 来开启一个 DateTime 拣选器: ```html <ion-item> <ion-label>预约时间</ion-label> <ion-datetime-button datetime="datetime-id"></ion-datetime-button> </ion-item> <ion-modal [isOpen]="true"> <ion-content> <ion-datetime id="datetime-id" presentation="date-time" [(ngModel)]="appointmentTime"></ion-datetime> </ion-content> </ion-modal> ``` 在这个实例里,当用户点击带有标签“预约时间”的项中的按钮时,会弹出模态窗口显示 DateTime 拣选器,其中设置时间会被绑定到变量 `appointmentTime` 上[^5]。 需要注意的是,在某些版本更新过程中(比如从 Ionic v5 到 v6),DateTime 组件内部实现有所改变,这可能影响现有应用的行为或外观表现。因此建议开发者仔细阅读官方文档并测试应用程序以确保兼容性和用户体验的一致性[^3]。 对于仅需图标的按钮情况,可以通过如下方式定义: ```html <!-- 只有图标 --> <button ion-button icon-only (click)="openDatetimePicker()"> <ion-icon name="calendar-outline"></ion-icon> </button> ``` 这里展示了创建只含图标的浮动操作按钮(FAB),并通过 `(click)` 事件处理器调用方法 `openDatetimePicker()` 打开拣选器[^4]。
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

陶洲川

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

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

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

打赏作者

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

抵扣说明:

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

余额充值