当前位置: 首页 > news >正文

QML中日期处理类

在 QML 中处理日期和时间主要使用 JavaScript 的 Date 对象以及 Qt 提供的一些相关功能。以下是常用的日期处理方式:

1. JavaScript Date 对象

QML 可以直接使用 JavaScript 的 Date 对象:

qml

// 创建当前日期时间
var currentDate = new Date()// 创建特定日期时间
var specificDate = new Date(2023, 11, 31) // 注意月份是0-11(11表示12月)

常用方法:

qml

// 获取日期各部分
var year = currentDate.getFullYear()
var month = currentDate.getMonth() + 1 // 需要+1因为月份从0开始
var day = currentDate.getDate()
var hours = currentDate.getHours()
var minutes = currentDate.getMinutes()
var seconds = currentDate.getSeconds()
var dayOfWeek = currentDate.getDay() // 0(周日)到6(周六)// 设置日期各部分
currentDate.setFullYear(2024)
currentDate.setMonth(5) // 6月
currentDate.setDate(15)// 格式化输出
var dateString = currentDate.toLocaleDateString()
var timeString = currentDate.toLocaleTimeString()
var dateTimeString = currentDate.toLocaleString()
toLocaleDateString()
功能:返回一个表示日期部分的字符串,使用操作系统的本地化约定。语法:javascript
dateObj.toLocaleDateString([locales[, options]])
示例:qml
var date = new Date();
console.log(date.toLocaleDateString()); 
// 输出取决于系统区域设置,如中文环境可能输出 "2023/12/31" 或 "2023年12月31日"
参数:locales (可选):指定语言代码的字符串或数组,如 "zh-CN", "en-US"options (可选):配置对象,可设置日期显示格式常用 options:javascript
var options = { weekday: 'long', // "short", "narrow"year: 'numeric', // "2-digit"month: 'long',   // "short", "narrow", "numeric", "2-digit"day: 'numeric'    // "2-digit"
};
date.toLocaleDateString('zh-CN', options);
// 输出示例:"2023年12月31日星期日"
toLocaleString()
功能:返回一个表示完整日期和时间的字符串,使用操作系统的本地化约定。语法:javascript
dateObj.toLocaleString([locales[, options]])
示例:qml
var date = new Date();
console.log(date.toLocaleString()); 
// 中文环境可能输出 "2023/12/31 下午3:45:30" 或 "2023年12月31日 15:45:30"
参数:同 toLocaleDateString(),但可以额外配置时间显示选项常用 options:javascript
var options = {year: 'numeric',month: 'numeric',day: 'numeric',hour: 'numeric',minute: 'numeric',second: 'numeric',hour12: false // 使用24小时制
};
date.toLocaleString('zh-CN', options);
// 输出示例:"2023/12/31 15:45:30"

 区别对比

方法输出内容典型输出示例
toLocaleDateString()仅日期部分"2023/12/31"
toLocaleString()日期和时间"2023/12/31 15:45:30"
toLocaleTimeString()仅时间部分"15:45:30"

 

2. Qt 提供的 QML 日期功能

Qt.formatDateTime()

qml

import QtQml 2.2// 格式化日期时间
Text {text: Qt.formatDateTime(new Date(), "yyyy-MM-dd hh:mm:ss")
}

Qt 提供了多种预定义格式:

  • Qt.DefaultLocaleShortDate

  • Qt.DefaultLocaleLongDate

  • Qt.ISODate 比如:yyyy-MM-dd hh:mm:ss

  • Qt.SystemLocaleShortDate

  • Qt.SystemLocaleLongDate

格式化选项:

  • "yyyy" - 4位数年份

  • "MM" - 2位数月份

  • "dd" - 2位数日期

  • "hh" - 2位数小时(12小时制)

  • "HH" - 2位数小时(24小时制)

  • "mm" - 2位数分钟

  • "ss" - 2位数秒数

  • "zzz" - 毫秒

  • "AP" - AM/PM指示器

import QtQuick 2.15
import QtQml 2.15Item {Component.onCompleted: {var now = new Date()console.log("Short date:", Qt.formatDateTime(now, Qt.DefaultLocaleShortDate))console.log("Long date:", Qt.formatDateTime(now, Qt.DefaultLocaleLongDate))console.log("ISO format:", Qt.formatDateTime(now, Qt.ISODate))console.log("Date only:", Qt.formatDate(now, Qt.DefaultLocaleLongDate))console.log("Time only:", Qt.formatTime(now, Qt.DefaultLocaleLongDate))}
}

3. 日期计算

qml

// 增加天数
var tomorrow = new Date()
tomorrow.setDate(tomorrow.getDate() + 1)// 计算日期差(毫秒数)
var date1 = new Date(2023, 0, 1)
var date2 = new Date(2023, 11, 31)
var diffMs = date2 - date1
var diffDays = diffMs / (1000 * 60 * 60 * 24)

4. 使用 Qt.locale() 本地化

qml

import QtQuick 2.0Text {text: Qt.locale().toString(new Date(), "yyyy年MM月dd日 ddd")
}

5. 时间戳处理

qml

// 获取当前时间戳(毫秒)
var timestamp = new Date().getTime()// 时间戳转日期
var dateFromTimestamp = new Date(timestamp)

6. 将 Date 对象格式化为本地化的日期字符串(不包含时间部分)

string Qt.formatDate(date, format)

参数

  • date:要格式化的 Date 对象

  • format:格式化选项,可以是:

    • Qt.DefaultLocaleShortDate - 短格式(如 "2023/12/31")

    • Qt.DefaultLocaleLongDate - 长格式(如 "2023年12月31日")

    • Qt.ISODate - ISO 格式(如 "2023-12-31")

    • 自定义格式字符串

使用示例

qml

import QtQuick 2.15
import QtQml 2.15Text {text: "今天是: " + Qt.formatDate(new Date(), Qt.DefaultLocaleLongDate)Component.onCompleted: {console.log("短格式日期:", Qt.formatDate(new Date(), Qt.DefaultLocaleShortDate))console.log("ISO格式日期:", Qt.formatDate(new Date(), Qt.ISODate))}
}

7. 将 Date 对象格式化为本地化的时间字符串(不包含日期部分)

string Qt.formatTime(date, format)

参数

  • date:要格式化的 Date 对象

  • format:格式化选项,可以是:

    • Qt.DefaultLocaleShortDate - 短格式(如 "15:45")

    • Qt.DefaultLocaleLongDate - 长格式(如 "下午3:45:30")

    • 自定义格式字符串

使用示例

qml

import QtQuick 2.15
import QtQml 2.15Text {text: "当前时间: " + Qt.formatTime(new Date(), Qt.DefaultLocaleLongDate)Component.onCompleted: {console.log("短格式时间:", Qt.formatTime(new Date(), Qt.DefaultLocaleShortDate))}
}

这些是 QML 中处理日期和时间最常用的方法和类。根据具体需求,你可以选择最适合的方式来处理日期和时间数据。

相关文章:

  • Oracle 23ai Vector Search 系列之6 向量相似性搜索(Similarity Search)
  • SpringBoot3集成ES8.15实现余额监控
  • 2. 什么是最普通的自动化“裸奔状态”?
  • 【Rust基础】使用Rocket从Token中提取用户信息
  • (mac)Grafana监控系统之监控Linux的Redis
  • Java基础类库常用类库 java.lang、java.util
  • 奇异递归模板设计模式-CRTP
  • Retinex系列图像/视频增强算法介绍
  • Docker Registry(镜像仓库)
  • Java开发软件
  • C++项目 —— 基于多设计模式下的同步异步日志系统(5)(单例模式)
  • Gen - CDPT举例说明:动态上下文前缀(输入先和标签结合,输出结果会更贴近标签内容)
  • 【ROS】航点导航功能
  • 解决vscode找不到Python自定义模块,报错No module named ‘xxx‘
  • 【Redis】Redis中的常见数据类型(一)
  • 通过爬虫方式实现头条号发布视频(2025年4月)
  • 常见的页面报错
  • Spring MVC 如何体现 Model-View-Controller 各自的职责?它们之间是如何协作的?
  • VS Code 远程连接服务器:Anaconda 环境与 Python/Jupyter 运行全指南。研0大模型学习(第六、第七天)
  • LicheeRV Nano 与Ubuntu官方risc-v 镜像混合
  • 京东:自21日起,所有超时20分钟以上的外卖订单全部免单
  • 长三角主流媒体将走进“来电”宜昌,探寻高质量发展密码
  • 撤销逾千名留学生签证,特朗普政府面临集体诉讼
  • 经济日报:从三个变化看外贸破局之道
  • 历史学家许福谦逝世,长期致力于魏晋南北朝史研究
  • 全国首个医工交叉“MD+PhD”双博士培养项目在沪启动