표준 빌트인 객체인 Date는 날짜와 시간 ( 연, 월, 일, 시 분, 초 , 밀리초)을 위한 메서드를 제공하는 빌트인 객체이면서 생성자 함수이다.
Date 생성자 함수
Date 생성자 함수로 객체를 새엇ㅇ하는 방법은 4가지가 있다.
1. new Date()
인수 없이 new 연산자와 함께 호출하면 현재 날짜와 시간을 가지는 Date객체를 반환한다.
2. new Date(milliseconds)
Date 생성자 함수에 숫자 타입의 밀리초를 인수로 전달하면 1970년 1월 1일 00:00:00 (UTC)를 기점으로 인수로 전달된 밀리초 만큼 경과한 날짜와 시간을 나타내는 객체를 반환한다.
3. new Date(dateString)
Date 생성자 함수에 날짜와 시간을 나타내는 문자열을 인수로 전달하면 지정된 날짜와 시간을 나타내는 Date 객체를 반환한다.
이때 인수로 전달한 문자열은 Date.parse 메서드에 의해 해석 가능한 형식이어야 한다.
4. new Date(year,month[,day,hour,minute,second,millisecond]
Date 생성자 함수에 연, 월 , 일 , 시, 분,초, 밀리초를 의미하는 숫자를 인수로 전달하면 지정된 날짜와 시간을 나타내는 Date객체를 반환한다. 이때 연 월은 반드시 지정해야하고 지정하지 않은 옵션 정보는 0또는 1로 초기화된다.
인수들
year : 연을 나타내는 1900년 이후의 정수 0~99는 1900부터 1999가 됨)
month : 월을 나타내는 0~11정수 (1월은 0 )
day : 일을 나타태는 1~31 정수
hour : 시를 나타내는 0~23까지의 정수
minute : 분을 나타내는 0~59정수
second : 초를 나타내는 0~59정수
millisecond : 밀리초를 나타내는 0~999 정수
//new Date()
console.log(new Date()); //2023-04-17T04:16:09.519Z
console.log(Date()); //Mon Apr 17 2023 13:16:09 GMT+0900 (대한민국 표준시)
//new Date(milliseconds)
console.log(new Date(0)); //1970-01-01T00:00:00.000Z
//1일
console.log(new Date(86400000)); //1970-01-02T00:00:00.000Z
//new Date(dateString)
console.log(new Date("May 26, 2020")); //2020-05-25T15:00:00.000Z
//new Date(year,month[,~~])
console.log(new Date("2020/3/26/10:00:00:00")); //2020-03-26T01:00:00.000Z
console.log(new Date(2020, 2)); //2020-02-29T15:00:00.000Z
Date 메서드
1.Date.now
1970년 1월 1일 00:00:00 UTC 기점으로 현재 시간까지 경과한 밀리초를 숫자로 반환함
2.Date.parse
1970년 1월 1일 00:00:00 UTC을 기점으로 인수로 전달된 지정 시간까지의 밀리초 까지 반환함.
(new Date(dateString)과 동일한 형식을 사용해야함)
3. Date.UTC
1970년 1월 1일 00:00:00 UTC을 기점으로 인수로 전달된 지정된 시간까지의 밀리초를 숫자로 반환함 (new Date(year.month[~~]와 동일한 형식 사용해야함)
4. Date.prototype.getFullYear
Date객체의 연도를 나타내는 정수를 반환한다.
5. Date.prototype.setFullYear
Date 객체에 연도를 나타내는 정수를 설정한다. 연도 이외에 옵션으로 월 일도 설정할 수 있다.
6. Date.prototype.getMonth
Date 객체의 월을 나타내는 0~11 정수를 반환한다. (1월은 0 )
7. Date.prototype.setMonth
Date 객체에 월을 나타내는 정수를 설정한다. 연도 이외에 옵션으로 일도 설정할 수 있다.
8.Date.prototype.getDate
Date 객체에 일을 나타내는 정수(1~31)를 반환한다.
9.Date.prototype.setDate
Date 객체에 날짜를 나타내는 정수를 설정한다.
10. Date.prototype.getDay
Date객체의 요일(0 : 월~6 : 일) 을 나타내는 정수를 반환한다.
11~12. Date.prototype.getHours, setHours
Date 객체의 시간을 나타내는 0~23 의 정수를 반환 및 설정한다. 설정의 경우 분 초 밀리초도 설정할 수 있다.
13~14 Date.prototype.getMinutes , setMinutes
Date 객체의 분을 나타내는 0~59의 정수를 반환 및 설정한다. 설정의 경우 초 밀리초도 설정할 수 있다.
15~16 Date.prototype.getSeconds ,setSeconds
Date 객체의 초을 나타내는 0~59의 정수를 반환 및 설정한다. 설정의 경우 밀리초도 설정할 수 있다.
17~18 Date.prototype.getMilliseconds ,setMilliSeconds
Date 객체의 밀리초를 나타내는 0~999의 정수를 반환 및 설정한다.
19~20 Date.prototype.getTime ,setTime
1970년 1월 1일 00:00:00 UTC 기점으로 Date 객체의 시간까지 경과된 밀리초를 반환 및 설정한다.
21. Date.prototype.getTimezoneOffset
UTC와 Date 객체에 지정된 로캘 시간과의 차이를 분 단위로 반환한다. KST +9 = UTC
//구글에서 실행
const today = new Date();
console.log(today);
console.log(today.getTimezoneOffset()); //540
VM61:2 Mon Apr 17 2023 13:33:51 GMT+0900 (한국 표준시)
VM61:3 -540
//node 환경 실행
const today = new Date();
console.log(today);
console.log(today.getTimezoneOffset()); //540
22.Date.prototype.toDateString
사람이 읽을 수 있는 형식의 문자열로 Date 객체의 날짜를 반환함
23.Date.prototype.toTimeString
사람이 읽을 수 있는 형식으로 Date 객체의 시간을 표현한 문자열을 반환함
24.Date.prototype.toISOString
ISO 8601 형식으로 Date 객체의 날짜와 시간을 표현한 문자열을 반환한다
25.Date.prototype.toLocaleString
인수로 전달한 로캘을 기준으로 Date 객체의 날짜와 시간을 표현한 문자열을 반환한다. 인수를 생략한 경우 브라우저가 동작중인 시스ㅋ템의 로켈을 적용한다.
26.Date.prototype.toLocaleTimeString
인수로 전달한 로캘을 기준으로 Date객체의 시간을 표현한 문자열을 반환한다. 인수 생략시 브라우저가 동작중인 로캘
const today = new Date("2070/7/24/12:30");
console.log(today.toString()); //Thu Jul 24 2070 12:30:00 GMT+0900 (대한민국 표준시)
console.log(today.toDateString()); //Thu Jul 24 2070
console.log(today.toTimeString()); //12:30:00 GMT+0900 (대한민국 표준시)
console.log(today.toISOString()); //2070-07-24T03:30:00.000Z
console.log(today.toLocaleString()); //2070. 7. 24. 오후 12:30:00
console.log(today.toLocaleString("ko-KR")); //2070. 7. 24. 오후 12:30:00
console.log(today.toLocaleString("en-US")); //7/24/2070, 12:30:00 PM
console.log(today.toLocaleTimeString("ko-KR")); //오후 12:30:00
'강의 노트 > JS' 카테고리의 다른 글
| [JS deep dive] String (0) | 2023.04.19 |
|---|---|
| [JS deepdive] RegExp (0) | 2023.04.18 |
| [JS deep dive] Math (0) | 2023.04.16 |
| [JS deep dive] Number (0) | 2023.04.16 |
| [JS deep dive] 배열 (0) | 2023.04.14 |