表达日期与时间

原创
admin 4个月前 (08-18) 阅读数 17 #JavaScript

表达日期与时间

JavaScript 没有专门的日期数据类型,但我们可以使用 Date 对象来处理日期和时间。Date 对象提供了丰富的方法来设置、获取和操作日期信息,尽管它本身不包含任何属性。

JavaScript 处理日期的方式与 Java 类似,两者共享许多相同的日期方法。它们都将日期存储为自 1970 年 1 月 1 日午夜(UTC 时间)以来的毫秒数,而 Unix 时间戳则是从同一时刻开始的秒数。1970 年 1 月 1 日午夜 UTC 这一时刻被称为"纪元"。

Date 对象的范围是从纪元前 100,000,000 天到纪元后 100,000,000 天。

创建 Date 对象

创建 Date 对象的基本语法如下:

const dateObjectName = new Date([parameters]);

其中 dateObjectName 是创建的 Date 对象的名称,可以是新对象或现有对象的属性。

如果不使用 new 关键字调用 Date,它会返回一个表示当前日期和时间的字符串。

上述语法中的 parameters 参数可以是以下几种形式之一:

  • 不传参数:创建当前日期和时间。例如,today = new Date();
  • 一个表示日期的字符串,支持多种格式,但始终支持 YYYY-MM-DDTHH:mm:ss.sssZ 格式。例如,xmas95 = new Date("1995-12-25")。如果省略小时、分钟或秒,则对应值会被设置为 0。
  • 一组表示年、月、日的整数。例如,xmas95 = new Date(1995, 11, 25)。
  • 一组表示年、月、日、时、分、秒的整数。例如,xmas95 = new Date(1995, 11, 25, 9, 30, 0);

Date 对象方法

Date 对象处理日期和时间的方法可分为以下几类:

  • "set"方法:用于设置 Date 对象中的日期和时间值。
  • "get"方法:用于获取 Date 对象中的日期和时间值。
  • "to"方法:用于返回 Date 对象中的字符串值。
  • parse 和 UTC 方法:用于解析 Date 字符串。

通过"get"和"set"方法,可以获取和设置秒、分钟、小时、月份中的日期、星期几、月份和年份。getDay 方法返回星期几,但没有对应的 setDay 方法,因为星期几是自动计算的。这些方法使用整数表示自身值,范围如下:

  • 秒和分钟:0 到 59
  • 小时:0 到 23
  • 星期:0(星期日)到 6(星期六)
  • 日期:1 到 31(月份中的天数)
  • 年份:自 1900 年以来的年数

例如,如果定义了以下日期:

const xmas95 = new Date("1995-12-25");

那么 xmas95.getMonth() 返回 11,xmas95.getFullYear() 返回 1995。

getTime 和 setTime 方法在日期比较中非常有用。getTime 方法返回 Date 对象自纪元以来的毫秒数。

例如,以下代码计算今年的剩余天数:

const today = new Date();
const endYear = new Date(1995, 11, 31, 23, 59, 59, 999);
endYear.setFullYear(today.getFullYear());
const msPerDay = 24 * 60 * 60 * 1000;
let daysLeft = (endYear.getTime() - today.getTime()) / msPerDay;
daysLeft = Math.round(daysLeft);

这个示例创建了一个名为 today 的 Date 对象,包含今天的日期。然后创建了一个名为 endYear 的 Date 对象,将年份设置为今年。通过一天时间的毫秒数计算 today 和 endYear 之间的天数差,最后使用 getTime 并取整天数。

parse 方法适用于将日期字符串的值赋给现有的 Date 对象。例如,以下代码使用 parse 和 setTime 方法将一个日期值赋给 ipoDate 对象:

const ipoDate = new Date();
ipoDate.setTime(Date.parse("Aug 9, 1995"));

示例

以下示例中,JSClock() 函数返回以数字时钟形式表示的时间。

function JSClock() {
  const time = new Date();
  const hour = time.getHours();
  const minute = time.getMinutes();
  const second = time.getSeconds();
  let temp = String(hour % 12);
  if (temp === "0") {
    temp = "12";
  }
  temp += (minute < 10 ? ":0" : ":") + minute;
  temp += (second < 10 ? ":0" : ":") + second;
  temp += hour >= 12 ? " P.M." : " A.M.";
  return temp;
}

JSClock 函数首先创建一个名为 time 的新 Date 对象,由于没有传参,因此用当前日期和时间创建 time。然后调用 getHours、getMinutes 和 getSeconds 方法将当前小时、分钟和秒的值赋给 hour、minute 和 second。

接下来的语句基于 time 构建了一个字符串值。第一条语句创建了一个 temp 变量,其值是 hour % 12,代表 12 小时制中的小时。然后判断,如果 hour 为 0,那么 temp 会被重新赋值为 12,以便午夜和正午时显示 12:00 而不是 0:00。

下一条语句给 temp 附加 minute 值。如果 minute 值小于 10,那么条件表达式将附加一个前置 0 字符串;否则,附加一个带有分隔冒号的字符串。随后的一条语句也以同样的方式附加秒数值到 temp。

最后,当 hour 大于等于 12 时,条件表达式附加"P.M."字符串到 temp;否则,附加"A.M."字符串到 temp。

版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权本站发表,未经许可,不得转载。

上一篇: 数字和字符串 下一篇: 正则表达式
作者文章
热门
最新文章
标签列表