您好,欢迎访问一九零五行业门户网

JavaScript Date对象详解_javascript技巧

本篇主要介绍 date 日期和时间对象的操作,具体内容如下
目录
1. 介绍:阐述 date 对象。
2. 构造函数:介绍 date 对象的构造函数new date()几种方式。
3. 实例方法:介绍 date 对象的get、set等实例方法。
4. 静态方法:介绍 date 对象的静态方法:date.now()、 date.parse()等。
5. 实际操作:介绍 date 对象的一些示例:获取倒计时、比较2个date对象的大小等等。
一. 介绍
1.1 说明
date对象,是操作日期和时间的对象。date对象对日期和时间的操作只能通过方法。
1.2 属性
无;date对象对日期和时间的操作只能通过方法。
二. 构造函数
2.1 new date() :返回当前的本地日期和时间
参数:无
返回值:
{date} 返回一个表示本地日期和时间的date对象。
示例:
var dt = new date();console.log(dt); // => 返回一个表示本地日期和时间的date对象
2.2 new date(milliseconds) :把毫秒数转换为date对象
参数:
①milliseconds {int} :毫秒数;表示从'1970/01/01 00:00:00'为起点,开始叠加的毫秒数。
注意:起点的时分秒还要加上当前所在的时区,北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00'
返回值:
{date} 返回一个叠加后的date对象。
示例:
var dt = new date(1000 * 60 * 1); // 前进1分钟的毫秒数console.log(dt); // => {date}:1970/01/01 08:01:00dt = new date(-1000 * 60 * 1); // 倒退1分钟的毫秒数console.log(dt); // => {date}:1970/01/01 07:59:00
2.3 new date(datestr) :把字符串转换为date对象
参数:
①datestr {string} :可转换为date对象的字符串(可省略时间);字符串的格式主要有两种:
1) yyyy/mm/dd hh:mm:ss (推荐):若省略时间,返回的date对象的时间为 00:00:00。
2) yyyy-mm-dd hh:mm:ss :若省略时间,返回的date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在ie中会转换失败!
返回值:
{date} 返回一个转换后的date对象。
示例:
var dt = new date('2014/12/25'); // yyyy/mm/ddconsole.log(dt); // => {date}:2014/12/25 00:00:00dt = new date('2014/12/25 12:00:00'); // yyyy/mm/dd hh:mm:ssconsole.log(dt); // => {date}:2014/12/25 12:00:00 dt = new date('2014-12-25'); // yyyy-mm-ddconsole.log(dt); // => {date}:2014-12-25 08:00:00 (加上了东8区的时区)dt = new date('2014-12-25 12:00:00'); // yyyy-mm-dd hh:mm:ss (注意:此转换方式在ie中会报错!)console.log(dt); // => {date}:2014-12-25 12:00:00
2.4 new date(year, month, opt_day, opt_hours, opt_minutes, opt_seconds, opt_milliseconds) :把年月日、时分秒转换为date对象
参数:
①year {int} :年份;4位数字。如:1999、2014
②month {int} :月份;2位数字。从0开始计算,0表示1月份、11表示12月份。
③opt_day {int} 可选:号; 2位数字;从1开始计算,1表示1号。
④opt_hours {int} 可选:时;2位数字;取值0~23。
⑤opt_minutes {int} 可选:分;2位数字;取值0~59。
⑥opt_seconds {int} 可选:秒;2未数字;取值0~59。
⑦opt_milliseconds {int} 可选:毫秒;取值0~999。
返回值:
{date} 返回一个转换后的date对象。
示例:
var dt = new date(2014, 11); // 2014年12月(这里输入的月份数字为11)console.log(dt); // => {date}:2014/12/01 00:00:00dt = new date(2014, 11, 25); // 2014年12月25日console.log(dt); // => {date}:2014/12/25 00:00:00dt = new date(2014, 11, 25, 15, 30, 40); // 2014年12月25日 15点30分40秒console.log(dt); // => {date}:2014/12/25 15:30:40dt = new date(2014, 12, 25); // 2014年13月25日(这里输入的月份数字为12,表示第13个月,跳转到第二年的1月)console.log(dt); // => {date}:2015/01/25
三. 实例方法
date对象的实例方法主要分为2种形式:本地时间和utc时间。同一个方法,一般都会有此2种时间格式操作(方法名带utc的,就是操作utc时间),这里主要介绍对本地时间的操作。
3.1 get方法
3.1.1 getfullyear() :返回date对象的年份值;4位年份。
3.1.2 getmonth() :返回date对象的月份值。从0开始,所以真实月份=返回值+1 。
3.1.3 getdate() :返回date对象的月份中的日期值;值的范围1~31 。
3.1.4 gethours() :返回date对象的小时值。
3.1.5 getminutes() :返回date对象的分钟值。
3.1.6 getseconds() :返回date对象的秒数值。
3.1.7 getmilliseconds() :返回date对象的毫秒值。
3.1.8 getday() :返回date对象的一周中的星期值;0为星期天,1为星期一、2为星期二,依此类推
3.1.9 gettime() :返回date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00') 。
示例:
dt.getfullyear(); // => 2014:年dt.getmonth(); // => 11:月;实际为12月份(月份从0开始计算)dt.getdate(); // => 25:日dt.gethours(); // => 15:时dt.getminutes(); // => 30:分dt.getseconds(); // => 40:秒dt.getmilliseconds(); // => 333:毫秒dt.getday(); // => 4:星期几的值dt.gettime(); // => 1419492640333 :返回date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')
3.2 set方法
3.2.1 setfullyear(year, opt_month, opt_date) :设置date对象的年份值;4位年份。
3.2.2 setmonth(month, opt_date) :设置date对象的月份值。0表示1月,11表示12月。
3.2.3 setdate(date) :设置date对象的月份中的日期值;值的范围1~31 。
3.2.4 sethours(hour, opt_min, opt_sec, opt_msec) :设置date对象的小时值。
3.2.5 setminutes(min, opt_sec, opt_msec) :设置date对象的分钟值。
3.2.6 setseconds(sec, opt_msec) :设置date对象的秒数值。
3.2.7 setmilliseconds(msec) :设置date对象的毫秒值。
示例:
var dt = new date();dt.setfullyear(2014); // => 2014:年dt.setmonth(11); // => 11:月;实际为12月份(月份从0开始计算)dt.setdate(25); // => 25:日dt.sethours(15); // => 15:时dt.setminutes(30); // => 30:分dt.setseconds(40); // => 40:秒dt.setmilliseconds(333); // => 333:毫秒console.log(dt); // => 2014年12月25日 15点30分40秒 333毫秒
3.3 其他方法
3.3.1 tostring() :将date转换为一个'年月日 时分秒'字符串
3.3.2 tolocalestring() :将date转换为一个'年月日 时分秒'的本地格式字符串
3.3.3 todatestring() :将date转换为一个'年月日'字符串
3.3.4 tolocaledatestring() :将date转换为一个'年月日'的本地格式字符串
3.3.5 totimestring() :将date转换为一个'时分秒'字符串
3.3.6 tolocaletimestring() :将date转换为一个'时分秒'的本地格式字符串
3.3.7 valueof() :与gettime()一样, 返回date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')
示例:
var dt = new date();console.log(dt.tostring()); // => tue dec 23 2014 22:56:11 gmt+0800 (中国标准时间) :将date转换为一个'年月日 时分秒'字符串console.log(dt.tolocalestring()); // => 2014年12月23日 下午10:56:11 :将date转换为一个'年月日 时分秒'的本地格式字符串 console.log(dt.todatestring()); // => tue dec 23 2014 :将date转换为一个'年月日'字符串console.log(dt.tolocaledatestring()); // => 2014年12月23日 :将date转换为一个'年月日'的本地格式字符串 console.log(dt.totimestring()); // => 22:56:11 gmt+0800 (中国标准时间) :将date转换为一个'时分秒'字符串console.log(dt.tolocaletimestring()); // => 下午10:56:11 :将date转换为一个'时分秒'的本地格式字符串 console.log(dt.valueof()); // => 返回date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')
四. 静态方法
4.1 date.now()
说明:返回当前日期和时间的date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')
参数:无
返回值:
{int} :当前时间与起始时间之间的毫秒数。
示例:
console.log(date.now()); // => 1419431519276
4.2 date.parse(datestr)
说明:把字符串转换为date对象 ,然后返回此date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')
参数:
①datestr {string} :可转换为date对象的字符串(可省略时间);字符串的格式主要有两种:
1) yyyy/mm/dd hh:mm:ss (推荐):若省略时间,返回的date对象的时间为 00:00:00。
2) yyyy-mm-dd hh:mm:ss :若省略时间,返回的date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在ie中返回nan(非数字)!
返回值:
{int} 返回转换后的date对象与起始时间之间的毫秒数。
示例:
console.log(date.parse('2014/12/25 12:00:00')); // => 1419480000000console.log(date.parse('2014-12-25 12:00:00')); // => 1419480000000 (注意:此转换方式在ie中返回nan!)
五. 实际操作
5.1 c#的datetime类型转换为js的date对象
说明:c#的datetime类型通过json序列化返回给前台的格式为:\/date(1419492640000)\/ 。中间的数字,表示datetime的值与起始时间之间的毫秒数。
示例:
后台代码:简单的ashx
public void processrequest (httpcontext context) { system.web.script.serialization.javascriptserializer js = new system.web.script.serialization.javascriptserializer(); datetime dt = datetime.parse(2014-12-25 15:30:40); string rs = js.serialize(dt); // 序列化成json context.response.contenttype = text/plain; context.response.write(rs);}
前台代码:
var datetimejsonstr = '\/date(1419492640000)\/'; // c# datetime类型转换的json格式var msecstr = datetimejsonstr.tostring().replace(/\/date\(([-]?\d+)\)\//gi, $1); // => '1419492640000' :通过正则替换,获取毫秒字符串var msesint = number.parseint(msecstr); // 毫秒字符串转换成数值var dt = new date(msesint); // 初始化date对象console.log(dt.tolocalestring()); // => 2014年12月25日 下午3:30:40
5.2 获取倒计时
说明:计算当前时间离目的时间相差多少天时分。
示例:
/*** 返回倒计时* @param dt {date}:目的date对象* @return {strin} :返回倒计时:x天x时x分*/function getdowntime(dt) { // 1.获取倒计时 var intervalmsec = dt - date.now(); // 目的时间减去现在的时间,获取两者相差的毫秒数 var intervalsec = intervalmsec / 1000; // 转换成秒数 var day = parseint(intervalsec / 3600 / 24); // 天数 var hour = parseint((intervalsec - day * 24 * 3600) / 3600); // 小时 var min = parseint((intervalsec - day * 24 * 3600 - hour * 3600) / 60); // 分钟 // 2.若相差的毫秒小于0 ,表示目的时间小于当前时间,这时的取的值都是负的:-x天-时-分,显示时,只显示天数前面为负的就行。 if (intervalmsec 154天10时33分console.log(getdowntime(new date('2014/01/01'))); // => -361天13时26分
5.3 比较2个date对象的大小
说明:可以对比2者的与起始时间的毫秒数,来区分大小。
示例:
var dt1 = new date('2015/12/01');var dt2 = new date('2015/12/25');console.log(dt1 > dt2); // => false
以上就是本文的全部内容,希望对大家的学习有所帮助。
其它类似信息

推荐信息