강의 노트/JS

[JS deep dive] Date

매망쩔 2023. 4. 17. 11:52

표준 빌트인 객체인 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