이 글에서는 주로 Date 날짜 및 시간 객체의 작동을 소개합니다.
1. 소개
1.1 설명
날짜 객체는 작업 날짜와 시간을 나타내는 객체입니다. Date 객체는 메소드를 통해서만 날짜와 시간에 대해 작동할 수 있습니다.
1.2 속성
없음
Date 객체는 메소드를 통해서만 날짜와 시간에 대해 작동할 수 있습니다.
2. 생성자
2.1 new Date(): 현재 현지 날짜와 시간을 반환
매개변수: 없음
반환 값:
{Date}는 현지 날짜와 시간을 나타내는 Date 객체를 반환합니다.
예:
var dt = new Date(); console.log(dt); // => 返回一个表示本地日期和时间的Date对象
2.2 new Date(밀리초): 밀리초를 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:00 dt = 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/dd console.log(dt); // => {Date}:2014/12/25 00:00:00 dt = new Date('2014/12/25 12:00:00'); // yyyy/MM/dd HH:mm:ss console.log(dt); // => {Date}:2014/12/25 12:00:00 dt = new Date('2014-12-25'); // yyyy-MM-dd console.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 새로운 날짜(년, 월, opt_day, opt_hours, opt_분, opt_seconds, opt_milliseconds): 년, 월, 일, 시, 분, 초를 Date 객체로 변환
매개변수:
①연도 {int}: 연도 4자리. 예: 1999, 2014
②월 {int}: 월 2자리. 계산은 0부터 시작하며 0은 1월을 나타내고 11은 12월을 나타냅니다.
③opt_day {int} 선택사항: 숫자 1부터 1은 1을 의미합니다.
④opt_hours {int} 선택사항: 시간 2자리 값;
⑤opt_분 {int} 선택사항: 분 2자리 값;
⑥opt_seconds {int} 선택 사항: 초 값 0~59.
7opt_milliseconds {int} 선택사항: 밀리초 값;
반환 값:
{Date}는 변환된 Date 객체를 반환합니다.
예:
var dt = new Date(2014, 11); // 2014年12月(这里输入的月份数字为11) console.log(dt); // => {Date}:2014/12/01 00:00:00 dt = new Date(2014, 11, 25); // 2014年12月25日 console.log(dt); // => {Date}:2014/12/25 00:00:00 dt = new Date(2014, 11, 25, 15, 30, 40); // 2014年12月25日 15点30分40秒 console.log(dt); // => {Date}:2014/12/25 15:30:40 dt = new Date(2014, 12, 25); // 2014年13月25日(这里输入的月份数字为12,表示第13个月,跳转到第二年的1月) console.log(dt); // => {Date}:2015/01/25
3. 인스턴스 메소드
Date 객체의 인스턴스 메소드는 크게 현지 시간과 UTC 시간의 두 가지 형태로 나뉩니다. 일반적으로 이 두 가지 시간 형식에 대해 동일한 방법이 작동합니다(UTC가 있는 방법 이름은 UTC 시간의 작동입니다). 여기서는 주로 현지 시간의 작동을 소개합니다.
3.1 get 메소드
예:
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方法
示例:
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 其他方法
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. 静态方法
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')); // => 1419480000000 console.log(Date.parse('2014-12-25 12:00:00')); // => 1419480000000 (注意:此转换方式在IE中返回NaN!)
分享的两个案例:
点击查看: 《javascript获取系统当前时间的方法》
点击查看: 《javascript电商网站抢购倒计时效果实现》
以上就是本文的全部内容,希望通过这篇文章大家更加了解javascript的Date对象,大家共同进步。