Qt之QDateEdit和QTimeEdit

简介: 简述QDateEdit类提供了一个部件,用于编辑日期。QTimeEdit类提供了一个部件,用于编辑时间。简述详细描述基本使用各司其职莫强求更多参考详细描述QDateEdit和QTimeEdit均继承自QDateTimeEdit,许多特性和功能都有QDateTimeEdit提供。这些都是相关属性:QDateEditda

简述

QDateEdit类提供了一个部件,用于编辑日期。QTimeEdit类提供了一个部件,用于编辑时间。

详细描述

QDateEdit和QTimeEdit均继承自QDateTimeEdit,许多特性和功能都有QDateTimeEdit提供。这些都是相关属性:

  • QDateEdit

    • date:保存了部件的显示日期。
    • minimumDate:定义了用户可以设置的最小日期。
    • maximumDate:定义了用户可以设置的最大日期。
    • displayFormat:包含了一个字符串用于格式化日期。
  • QTimeEdit

    • time:保存了部件的显示时间。
    • minimumTime:定义了用户可以设置的最小时间。
    • maximumTime:定义了用户可以设置的最大时间。
    • displayFormat:包含了一个字符串用于格式化时间。

前面的众多文章,基本上都在分享的如何使用?本节比较特殊,因为该讲的在Qt之QDateTimeEdit一节已经分享过了。下面主要分享QDateEdit和QTimeEdit使用过程中可能遇到的坑。

基本使用

使用QDateEdit时,如果不设置日期,则系统会为其指定一个默认的日期:2000年1月1日。使用QTimeEdit时,如果不设置时间,则系统会为其指定一个默认的时间:0时0分0秒。所以,我们一般都会指定一个合适的日期和时间(当前日期时间)。

这里写图片描述

QDateEdit *dateEdit = new QDateEdit(QDate::currentDate(), this);
QTimeEdit *timeEdit = new QTimeEdit(QTime::currentTime(), this);

各司其职

如上所述,QDateEdit用于编辑日期,而QTimeEdit用于编辑时间。所以不要用QDateEdit来设置或获取时间,也不要用QTimeEdit来设置或获取日期。如果要同时操作日期时间,请使用QDateTimeEdit。

这里写图片描述

QDateEdit *dateEdit = new QDateEdit(this);
QTimeEdit *timeEdit = new QTimeEdit(this);

// 错误(语法正确)
dateEdit->setDisplayFormat("yyyy/MM/dd HH:mm:ss");
timeEdit->setDisplayFormat("yyyy/MM/dd HH:mm:ss");

// 正确
//dateEdit->setDisplayFormat("yyyy/MM/dd");
//timeEdit->setDisplayFormat("HH:mm:ss");

// 设置日期时间
dateEdit->setDateTime(QDateTime::currentDateTime());
timeEdit->setDateTime(QDateTime::currentDateTime());

显然,当点击QDateEdit的上下箭头时,只能改变日期,而改变不了时间。同理,当点击QTimeEdit的上下箭头时,只能改变时间,而改变不了日期。

所以,即使语法正确,也不建议把QDateEdit和QTimeEdit当做QDateTimeEdit来用。

注意:即使是设置显示格式,对于QDateEdit来说,只需要设置年月日即可,例如:yyyy/MM/dd;对于QTimeEdit只需要设置时分秒,例如:HH:mm:ss。

莫强求

命里有时终须有,命里无时莫强求。

在QDateTimeEdit使用过程中,分享了如何显示日历。而日历是对应的是QDate,而非QTime。所以QDateEdit、QDateTimeEdit可以使用,而QTimeEdit并不能使用。

QDateTimeEdit *dateTimeEdit = new QDateTimeEdit(this);
QDateEdit *dateEdit = new QDateEdit(this);
QTimeEdit *timeEdit = new QTimeEdit(this);

dateTimeEdit->setCalendarPopup(true);  // 正确
dateEdit->setCalendarPopup(true);  // 正确
timeEdit->setCalendarPopup(true);  // 错误(语法正确)

对于QTimeEdit来说,虽然语法上可以通过,但是其实做了无用功,纯属冗余代码,毫无意义!

写代码时,有些人喜欢各种乱试,可以就Ok,不可以就拉倒。这种心态不可取,更多时候需要做到知其然,并知其所以然!

更多参考

目录
相关文章
|
7月前
【Qt】- QMainWindwo
【Qt】- QMainWindwo
|
7月前
|
Linux 定位技术 C++
【Qt】-学Qt前的准备
【Qt】-学Qt前的准备
|
7月前
|
前端开发 编译器 开发工具
Qt
Qt
347 0
|
存储 Cloud Native 前端开发
Qt QScrollArea使用
Qt QScrollArea使用
26 QT - 事件过滤器
26 QT - 事件过滤器
54 0
|
存储
Qt之QLCDNumber
Qt之QLCDNumber
379 0
|
Java C++
Qt之QFuture
简述 QFuture 类代表一个异步计算的结果。 要启动一个计算,使用 Qt之Concurrent框架 中的 APIs 之一。 QFuture 允许线程与一个或多个结果同步,这些结果将在稍后的时间点准备就绪,该结果可以是具有默认构造函数和拷贝构造函数的任何类型。如果一个结果在调用 result()、resultAt() 或 results() 函数时不可用,QFutur
2052 0
|
存储 安全 Windows
Qt之QEvent
简述 QEvent 类是所有事件类的基类,事件对象包含事件参数。 Qt 的主事件循环(QCoreApplication::exec())从事件队列中获取本地窗口系统事件,将它们转化为 QEvents,然后将转换后的事件发送给 QObjects。 一般来说,事件来自底层窗口系统(spontaneous() 返回 true),但也可以使用 QCoreApplication:
1831 0
|
缓存 Unix Windows
Qt之QLocalSocket
简述 QLocalSocket类提供了一个本地socket。 在Windows中,这是一个命名管道;在Unix中,这是一个本地网域socket。 如果发生错误,socketError()会返回错误的类型,errorString()则返回人类可读的错误描述。 虽然QLocalSocket是一个事件循环使用而设计,它也可以不被如此使用。这种情况下,必须使用 waitF
2679 0