通过实例解析javascript Date对象属性及方法
日常生活中,各种形式的时间字符到处都是。时间观念的产生,时间单位、计时工具的发明,给人类带来的变化实在一言难尽。今天就来谈谈日期那些事儿。一起来看看 JavaScript 中的日期对象 Date。
获取月份天数
// 获取月份天数 function getMonthDayCount(year, month) { return new Date(year, month, 0).getDate(); } console.log(getMonthDayCount(2017, 10)); // 31
Date 第三个参数的本质跟 setDate 是一样的。
因为 date 为 0 时自动退到上个月的最后一天,所以这里月份也不需要减,正好的。
获取所有月份天数
function getAllMonthDayCount(year) { var days = [31, new Date(year, 2, 0).getDate(), 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; return days; } console.log(getAllMonthDayCount(2016));// [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
这个算是上面的延伸,不多解释。
是否是闰年
function isLeapYear(year) { return (year % 4 == 0) && (year % 100 != 0 || year % 400 == 0); }
这是网上的web前端开发里相关代码,相信大多数人都用。但其实你真的理解或者能记住么?光是html和css就足够多记的了
function isLeapYear(year) { return new Date(year, 2, 0).getDate() === 29; } console.log([ isLeapYear(2000), isLeapYear(2016), isLeapYear(2017), isLeapYear(2018) ]); // [ true, true, false, false ]
这样看,是不是就非常简单容易理解了。
而且都不需要记,是不是想忘都忘不了?
天数加减操作
之前看到有人用相对秒数在计算几天前或几天后,甚至还在算跨月,跨年的情况。
其实直接 setDate 就好了,自动处理 跨月,跨年 的情况。
// 10天后是几月几号
var dt = new Date('2016-12-25');
dt.setDate(dt.getDate() + 10);
console.log(dt.toLocaleDateString()); // 2017/1/4
// 10天前是几月几号
var dt = new Date('2017-01-04');
dt.setDate(dt.getDate() - 10);
console.log(dt.toLocaleDateString()); // 2016/12/25
狼蚁网站SEO优化我将JavaScript Date 对象的对象和方法总结成一个表,让大家参考,也可以关注javascript参考手册。
Date 对象属性
属性 | 描述 |
---|---|
返回对创建此对象的 Date 函数的引用。 | |
使您有能力向对象添加属性和方法。 |
Date 对象方法
方法 | 描述 |
---|---|
返回当日的日期和时间。 | |
从 返回一个月中的某一天 (1 ~ 31)。 | |
从 Date 对象返回一周中的某一天 (0 ~ 6)。 | |
从 Date 对象返回月份 (0 ~ 11)。 | |
从 Date 对象以四位数字返回年份。 | |
请使用 getFullYear() 方法代替。 | |
返回 Date 对象的小时 (0 ~ 23)。 | |
返回 Date 对象的分钟 (0 ~ 59)。 | |
返回 Date 对象的秒数 (0 ~ 59)。 | |
返回 Date 对象的毫秒(0 ~ 999)。 | |
返回 1970 年 1 月 1 日至今的毫秒数。 | |
返回本地时间与格林威治标准时间 (GMT) 的分钟差。 | |
根据世界时从 Date 对象返回月中的一天 (1 ~ 31)。 | |
根据世界时从 Date 对象返回周中的一天 (0 ~ 6)。 | |
根据世界时从 Date 对象返回月份 (0 ~ 11)。 | |
根据世界时从 Date 对象返回四位数的年份。 | |
根据世界时返回 Date 对象的小时 (0 ~ 23)。 | |
根据世界时返回 Date 对象的分钟 (0 ~ 59)。 | |
根据世界时返回 Date 对象的秒钟 (0 ~ 59)。 | |
根据世界时返回 Date 对象的毫秒(0 ~ 999)。 | |
返回1970年1月1日午夜到指定日期(字符串)的毫秒数。 | |
设置 Date 对象中月的某一天 (1 ~ 31)。 | |
设置 Date 对象中月份 (0 ~ 11)。 | |
设置 Date 对象中的年份(四位数字)。 | |
请使用 setFullYear() 方法代替。 | |
设置 Date 对象中的小时 (0 ~ 23)。 | |
设置 Date 对象中的分钟 (0 ~ 59)。 | |
设置 Date 对象中的秒钟 (0 ~ 59)。 | |
设置 Date 对象中的毫秒 (0 ~ 999)。 | |
以毫秒设置 Date 对象。 | |
根据世界时设置 Date 对象中月份的一天 (1 ~ 31)。 | |
根据世界时设置 Date 对象中的月份 (0 ~ 11)。 | |
根据世界时设置 Date 对象中的年份(四位数字)。 | |
根据世界时设置 Date 对象中的小时 (0 ~ 23)。 | |
根据世界时设置 Date 对象中的分钟 (0 ~ 59)。 | |
根据世界时设置 Date 对象中的秒钟 (0 ~ 59)。 | |
根据世界时设置 Date 对象中的毫秒 (0 ~ 999)。 | |
返回该对象的源代码。 | |
把 Date 对象转换为字符串。 | |
把 Date 对象的时间部分转换为字符串。 | |
把 Date 对象的日期部分转换为字符串。 | |
请使用 toUTCString() 方法代替。 | |
根据世界时,把 Date 对象转换为字符串。 | |
根据本地时间格式,把 Date 对象转换为字符串。 | |
根据本地时间格式,把 Date 对象的时间部分转换为字符串。 | |
根据本地时间格式,把 Date 对象的日期部分转换为字符串。 | |
根据世界时返回 1970 年 1 月 1 日 到指定日期的毫秒数。 | |
返回 Date 对象的原始值。 |
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。