DateTime 类
DateTime类用来标识一个瞬时的时间节点,可以通过构造函数,从标准格式(符合ISO 8601标准)的字符串中构造一个时间对象。DateTIme使用24小时计时法。以下是最基础的例子:
var now = new DateTime.now();
var berlinWallFell = new DateTime.utc(1989, 11, 9);
var moonLanding = DateTime.parse("1969-07-20 20:18:04Z"); // 8:18pm
DateTime对象会锚定UTC(通用协调时Universal Time Coordinated)时区或者设备的本地时区。在创建之后,DateTime的值和所属的时区都不会改变。可以通过对象属性读取具体的时间值:
assert(berlinWallFell.month == 11); // 柏林墙倒塌的月份
assert(moonLanding.hour == 20); // 登月时的时间(小时)
出于便捷性和可读性的考量,DateTIme类提供了星期和月份的常量值可供调用,你可以使用很多常量来提高代码的可读性,示例如下:
var berlinWallFell = new DateTime.utc(1989, DateTime.november, 9);
assert(berlinWallFell.weekday == DateTime.thursday);
星期和月份的常量都是从1开始的,每周的开始从周一开始计算,所以january和monday的值都是1。
构造方法
DateTime(int year, [ int month = 1 int day = 1 int hour = 0 int minute = 0 int second = 0 int millisecond = 0 int microsecond = 0 ])
该方法创建一个依托于本地时区的DateTime实例
DateTime.fromMicrosecondsSinceEpoch(int microsecondsSinceEpoch, { bool isUtc: false })
该方法输入距离1970年1月1日0时0分0秒的微秒数,得到一个DateTime实例。
DateTime.fromMillisecondsSinceEpoch(int millisecondsSinceEpoch, { bool isUtc: false })
该方法输入距离1970年1月1日0时0分0秒的毫秒数,得到一个DateTime实例。
DateTime.now()
该方法返回一个依托于本地时区的代