ν‘œμ€€ 빌트인 객체인 DataλŠ” λ‚ μ§œμ™€ μ‹œκ°„μ„ μœ„ν•œ λ©”μ„œλ“€μ„ μ œκ³΅ν•˜λŠ” 빌트인 κ°μ²΄μ΄λ©΄μ„œ μƒμ„±μž ν•¨μˆ˜λ‹€.

⏰ 30.1 Data μƒμ„±μž ν•¨μˆ˜

βœ” 30.1.1 new Date()

Date μƒμ„±μž ν•¨μˆ˜λ₯Ό 인수 없이 new μ—°μ‚°μžμ™€ ν•¨κ»˜ ν˜ΈμΆœν•˜λ©΄ ν˜„μž¬ λ‚ μ§œμ™€ μ‹œκ°„μ„ κ°–λŠ” Date 객체λ₯Ό λ°˜ν™˜ν•œλ‹€. Date κ°μ²΄λŠ” λ‚΄λΆ€μ μœΌλ‘œ λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜κ°’μ„ κ°–μ§€λ§Œ Date 객체λ₯Ό μ½˜μ†”μ— 좜λ ₯ν•˜λ©΄ 기본적으둜 λ‚ μ§œμ™€ μ‹œκ°„ 정보λ₯Ό 좜λ ₯ν•œλ‹€.

new Date(); // -> Mon Jul 06 2020 01:03:18 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
Date(); // -> "Mon Jul 06 2020 01:10:47 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)"

Date μƒμ„±μž ν•¨μˆ˜λ₯Ό new μ—°μ‚°μž 없이 ν˜ΈμΆœν•˜λ©΄ Date 객체λ₯Ό λ°˜ν™˜ν•˜μ§€ μ•Šκ³  λ‚ μ§œμ™€ μ‹œκ°„ 정보λ₯Ό λ‚˜νƒ€λ‚΄λŠ” λ¬Έμžμ—΄μ„ λ°˜ν™˜ν•œλ‹€.

Date(); // -> "Mon Jul 06 2020 01:10:47 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)"

βœ” 30.1.2 new Date(milliseconds)

Date μƒμ„±μž ν•¨μˆ˜μ— 숫자 νƒ€μž…μ˜ λ°€λ¦¬μ΄ˆλ₯Ό 인수둜 μ „λ‹¬ν•˜λ©΄ 1970λ…„ 1μ›” 1일을 기점으둜 인수둜 μ „λ‹¬λœ λ°€λ¦¬μ΄ˆλ§ŒνΌ κ²½κ³Όν•œ λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” Date 객체λ₯Ό λ°˜ν™˜ν•œλ‹€.

// ν•œκ΅­ ν‘œμ€€μ‹œ KSTλŠ” ν˜‘μ • μ„Έκ³„μ‹œ UTC에 9μ‹œκ°„μ„ λ”ν•œ μ‹œκ°„μ΄λ‹€.
new Date(0); // -> Thu Jan 01 1970 09:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

/*
86400000msλŠ” 1dayλ₯Ό μ˜λ―Έν•œλ‹€.
1s = 1,000ms
1m = 60s * 1,000ms = 60,000ms
1h = 60m * 60,000ms = 3,600,000ms
1d = 24h * 3,600,000ms = 86,400,000ms
*/
new Date(86400000); // -> Fri Jan 02 1970 09:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

βœ” 30.1.3 new Date(dataString)

Date μƒμ„±μž ν•¨μˆ˜μ— λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” λ¬Έμžμ—΄μ„ 인수둜 μ „λ‹¬ν•˜λ©΄ μ§€μ •λœ λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” Date 객체λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('May 26, 2020 10:00:00');
// -> Tue May 26 2020 10:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

new Date('2020/03/26/10:00:00');
// -> Thu Mar 26 2020 10:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

βœ” 30.1.4 new Date(year, month, [day, hour, minute, second, millisecond])

Date μƒμ„±μž ν•¨μˆ˜μ— μ—°, μ›”, 일, μ‹œ λΆ„ 초, λ°€λ¦¬μ΄ˆλ₯Ό μ˜λ―Έν•˜λŠ” 숫자λ₯Ό 인수둜 μ „λ‹¬ν•˜λ©΄ μ§€μ •λœ λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” Date 객체λ₯Ό λ°˜ν™˜ν•œλ‹€. μ΄λ•Œ μ—°, 월은 λ°˜λ“œμ‹œ 지정해야 ν•œλ‹€.

// 월을 λ‚˜νƒ€λ‚΄λŠ” 2λŠ” 3월을 μ˜λ―Έν•œλ‹€. 2020/3/1/00:00:00:00
new Date(2020, 2);
// -> Sun Mar 01 2020 00:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

// 월을 λ‚˜νƒ€λ‚΄λŠ” 2λŠ” 3월을 μ˜λ―Έν•œλ‹€. 2020/3/26/10:00:00:00
new Date(2020, 2, 26, 10, 00, 00, 0);
// -> Thu Mar 26 2020 10:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

// λ‹€μŒμ²˜λŸΌ ν‘œν˜„ν•˜λ©΄ 가독성이 훨씬 μ’‹λ‹€.
new Date('2020/3/26/10:00:00:00');
// -> Thu Mar 26 2020 10:00:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

⏰ 30.2 Date λ©”μ„œλ“œ

βœ” 30.2.1 Date.now

1970λ…„ 1μ›” 1일 00:00:00(UTC)을 기점으둜 ν˜„μž¬ μ‹œκ°„κΉŒμ§€ κ²½κ³Όν•œ λ°€λ¦¬μ΄ˆλ₯Ό 숫자둜 λ°˜ν™˜ν•œλ‹€.

const now = Date.now(); // -> 1593971539112

// Date μƒμ„±μž ν•¨μˆ˜μ— 숫자 νƒ€μž…μ˜ λ°€λ¦¬μ΄ˆλ₯Ό 인수둜 μ „λ‹¬ν•˜λ©΄ 1970λ…„ 1μ›” 1일 00:00:00(UTC)을
// 기점으둜 인수둜 μ „λ‹¬λœ λ°€λ¦¬μ΄ˆλ§ŒνΌ κ²½κ³Όν•œ λ‚ μ§œμ™€ μ‹œκ°„μ„ λ‚˜νƒ€λ‚΄λŠ” Date 객체λ₯Ό λ°˜ν™˜ν•œλ‹€.
// (30.1.2절 "new Date(milliseconds)" 참고)
new Date(now); // -> Mon Jul 06 2020 02:52:19 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

βœ” 30.2.2 Date.parse

1970λ…„ 1μ›” 1일 00:00:00(UTC)을 기점으둜 인수둜 μ „λ‹¬λœ 지정 μ‹œκ°„(new Date(dateString)의 μΈμˆ˜μ™€ λ™μΌν•œ ν˜•μ‹)κΉŒμ§€μ˜ λ°€λ¦¬μ΄ˆλ₯Ό 숫자둜 λ°˜ν™˜ν•œλ‹€.

// UTC
Date.parse('Jan 2, 1970 00:00:00 UTC'); // -> 86400000

// KST
Date.parse('Jan 2, 1970 09:00:00'); // -> 86400000

// KST
Date.parse('1970/01/02/09:00:00');  // -> 86400000

βœ” 30.2.3 Date.UTC

1970λ…„ 1μ›” 1일 00:00:00(UTC)을 기점으둜 인수둜 μ „λ‹¬λœ 지정 μ‹œκ°„κΉŒμ§€μ˜ λ°€λ¦¬μ΄ˆλ₯Ό 숫자둜 λ°˜ν™˜ν•œλ‹€.

Date.UTC(1970, 0, 2); // -> 86400000
Date.UTC('1970/1/2'); // -> NaN

βœ” 30.2.4 Date.prototype.getFullYear

Date 객체의 연도λ₯Ό λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24').getFullYear(); // -> 2020

βœ” 30.2.5 Date.prototype.setFullYear

Date 객체에 연도λ₯Ό λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€. 연도 이외에 μ˜΅μ…˜μœΌλ‘œ μ›”, 일도 μ„€μ •ν•  수 μžˆλ‹€.

const today = new Date();

// 년도 지정
today.setFullYear(2000);
today.getFullYear(); // -> 2000

// 년도/μ›”/일 지정
today.setFullYear(1900, 0, 1);
today.getFullYear(); // -> 1900

βœ” 30.2.6 Date.prototype.getMonth

Date 객체의 월을 λ‚˜νƒ€λ‚΄λŠ” 0 ~ 11의 μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€. 1월은 0이닀.

new Date('2020/07/24').getMonth(); // -> 6

βœ” 30.2.7 Date.prototype.setMonth

Date 객체의 월을 λ‚˜νƒ€λ‚΄λŠ” 0 ~ 11의 μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€. μ˜΅μ…˜μœΌλ‘œ 일도 μ„€μ •ν•  수 μžˆλ‹€.

const today = new Date();

// μ›” 지정
today.setMonth(0); // 1μ›”
today.getMonth(); // -> 0

// μ›”/일 지정
today.setMonth(11, 1); // 12μ›” 1일
today.getMonth(); // -> 11

βœ” 30.2.8 Date.prototype.getDate

Date 객체의 λ‚ μ§œ(1~31)λ₯Ό λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24').getDate(); // -> 24

βœ” 30.2.9 Date.prototype.setDate

Date 객체의 λ‚ μ§œ(1~31)λ₯Ό λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€.

const today = new Date();

// λ‚ μ§œ 지정
today.setDate(1);
today.getDate(); // -> 1

βœ” 30.2.10 Date.prototype.getDay

Date 객체의 μš”μΌ(0~6)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€. μΌμš”μΌμ΄ 0이닀.

new Date('2020/07/24').getDay(); // -> 5

βœ” 30.2.11 Date.prototype.getHours

Date 객체의 μ‹œκ°„(0~23)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24/12:00').getHours(); // -> 12

βœ” 30.2.12 Date.prototype.setHours

Date 객체의 μ‹œκ°„(0~23)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€.

const today = new Date();

// μ‹œκ°„ 지정
today.setHours(7);
today.getHours(); // -> 7

// μ‹œκ°„/λΆ„/초/λ°€λ¦¬μ΄ˆ 지정
today.setHours(0, 0, 0, 0); // 00:00:00:00
today.getHours(); // -> 0

βœ” 30.2.13 Date.prototype.getMiniutes

Date 객체의 λΆ„(0~59)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24/12:30').getMinutes(); // -> 30

βœ” 30.2.14 Date.prototype.setMiniutes

Date 객체의 λΆ„(0~59)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€.

const today = new Date();

// λΆ„ 지정
today.setMinutes(50);
today.getMinutes(); // -> 50

// λΆ„/초/λ°€λ¦¬μ΄ˆ 지정
today.setMinutes(5, 10, 999); // HH:05:10:999
today.getMinutes(); // -> 5

βœ” 30.2.15 Date.prototype.getSeconds

Date 객체의 초(0~59)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24/12:30').getMinutes(); // -> 30

βœ” 30.2.16 Date.prototype.setSeconds

Date 객체의 초(0~59)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€.

const today = new Date();

// λΆ„ 지정
today.setMinutes(50);
today.getMinutes(); // -> 50

// λΆ„/초/λ°€λ¦¬μ΄ˆ 지정
today.setMinutes(5, 10, 999); // HH:05:10:999
today.getMinutes(); // -> 5

βœ” 30.2.17 Date.prototype.getMilliseconds

Date 객체의 λ°€λ¦¬μ΄ˆ(0~999)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24/12:30').getMinutes(); // -> 30

βœ” 30.2.18 Date.prototype.setMilliseconds

Date 객체의 λ°€λ¦¬μ΄ˆ(0~999)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό μ„€μ •ν•œλ‹€.

const today = new Date();

// λΆ„ 지정
today.setMinutes(50);
today.getMinutes(); // -> 50

// λΆ„/초/λ°€λ¦¬μ΄ˆ 지정
today.setMinutes(5, 10, 999); // HH:05:10:999
today.getMinutes(); // -> 5

βœ” 30.2.19 Date.prototype.getTime

1970λ…„ 1μ›” 1일 00:00:00(UTC)λ₯Ό 기점으둜 Date 객체의 μ‹œκ°„κΉŒμ§€ 경과된 λ°€λ¦¬μ΄ˆλ₯Ό λ°˜ν™˜ν•œλ‹€.

new Date('2020/07/24/12:30').getMinutes(); // -> 30

βœ” 30.2.20 Date.prototype.setTime

1970λ…„ 1μ›” 1일 00:00:00(UTC)λ₯Ό 기점으둜 Date 객체의 μ‹œκ°„κΉŒμ§€ 경과된 λ°€λ¦¬μ΄ˆλ₯Ό λ°˜ν™˜ν•œλ‹€.

const today = new Date();

// λΆ„ 지정
today.setMinutes(50);
today.getMinutes(); // -> 50

// λΆ„/초/λ°€λ¦¬μ΄ˆ 지정
today.setMinutes(5, 10, 999); // HH:05:10:999
today.getMinutes(); // -> 5

βœ” 30.2.21 Date.prototype.getTimezoneOffset

UTC와 Date 객체에 μ§€μ •λœ 둜캘 μ‹œκ°„κ³Όμ˜ 차이λ₯Ό λΆ„ λ‹¨μœ„λ‘œ λ°˜ν™˜ν•œλ‹€.

const today = new Date(); // today의 지정 λ‘œμΊ˜μ€ KSTλ‹€.

//UTC와 today의 지정 둜캘 KSTμ™€μ˜ μ°¨μ΄λŠ” -9μ‹œκ°„μ΄λ‹€.
today.getTimezoneOffset() / 60; // -9

βœ” 30.2.22 Date.prototype.toDateString

μ‚¬λžŒμ΄ 읽을 수 μžˆλŠ” ν˜•μ‹μ˜ λ¬Έμžμ—΄λ‘œ Date 객체의 λ‚ μ§œλ₯Ό λ°˜ν™˜ν•œλ‹€.

const today = new Date('2020/7/24/12:30');

today.toString();     // -> Fri Jul 24 2020 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
today.toDateString(); // -> Fri Jul 24 2020

βœ” 30.2.23 Date.prototype.toTimeString

μ‚¬λžŒμ΄ 읽을 수 μžˆλŠ” ν˜•μ‹μ˜ λ¬Έμžμ—΄λ‘œ Date 객체의 μ‹œκ°„μ„ λ°˜ν™˜ν•œλ‹€.

const today = new Date('2020/7/24/12:30');

today.toString();     // -> Fri Jul 24 2020 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
today.toTimeString(); // -> 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)

βœ” 30.2.24 Date.prototype.toISOString

ISO 8601ν˜•μ‹μœΌλ‘œ Date λ‚ μ§œμ™€ μ‹œκ°„μ„ ν‘œν˜„ν•œ λ¬Έμžμ—΄μ„ λ°˜ν™˜ν•œλ‹€.

const today = new Date('2020/7/24/12:30');

today.toString();    // -> Fri Jul 24 2020 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
today.toISOString(); // -> 2020-07-24T03:30:00.000Z

today.toISOString().slice(0, 10); // -> 2020-07-24
today.toISOString().slice(0, 10).replace(/-/g, ''); // -> 20200724

βœ” 30.2.25 Date.prototype.toLocaleString

인수둜 μ „λ‹¬ν•œ λ‘œμΊ˜μ„ κΈ°μ€€μœΌλ‘œ Date 객체의 λ‚ μ§œμ™€ μ‹œκ°„μ„ ν‘œν˜„ν•œ λ¬Έμžμ—΄μ„ λ°˜ν™˜ν•œλ‹€.

const today = new Date('2020/7/24/12:30');

today.toString(); // -> Fri Jul 24 2020 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
today.toLocaleString(); // -> 2020. 7. 24. μ˜€ν›„ 12:30:00
today.toLocaleString('ko-KR'); // -> 2020. 7. 24. μ˜€ν›„ 12:30:00
today.toLocaleString('en-US'); // -> 7/24/2020, 12:30:00 PM
today.toLocaleString('ja-JP'); // -> 2020/7/24 12:30:00

βœ” 30.2.26 Date.prototype.toLocaleTimeString

인수둜 μ „λ‹¬ν•œ λ‘œμΊ˜μ„ κΈ°μ€€μœΌλ‘œ Date 객체의 μ‹œκ°„μ„ ν‘œν˜„ν•œ λ¬Έμžμ—΄μ„ λ°˜ν™˜ν•œλ‹€.

const today = new Date('2020/7/24/12:30');

today.toString(); // -> Fri Jul 24 2020 12:30:00 GMT+0900 (λŒ€ν•œλ―Όκ΅­ ν‘œμ€€μ‹œ)
today.toLocaleTimeString(); // -> μ˜€ν›„ 12:30:00
today.toLocaleTimeString('ko-KR'); // -> μ˜€ν›„ 12:30:00
today.toLocaleTimeString('en-US'); // -> 12:30:00 PM
today.toLocaleTimeString('ja-JP'); // -> 12:30:00

⏰ 30.3 Dateλ₯Ό ν™œμš©ν•œ μ‹œκ³„ 예제

(function printNow() {
  const today = new Date();

  const dayNames = [
    '(μΌμš”μΌ)',
    '(μ›”μš”μΌ)',
    '(ν™”μš”μΌ)',
    '(μˆ˜μš”μΌ)',
    '(λͺ©μš”일)',
    '(κΈˆμš”μΌ)',
    '(ν† μš”μΌ)'
  ];
  // getDay λ©”μ„œλ“œλŠ” ν•΄λ‹Ή μš”μΌ(0 ~ 6)을 λ‚˜νƒ€λ‚΄λŠ” μ •μˆ˜λ₯Ό λ°˜ν™˜ν•œλ‹€.
  const day = dayNames[today.getDay()];

  const year = today.getFullYear();
  const month = today.getMonth() + 1;
  const date = today.getDate();
  let hour = today.getHours();
  let minute = today.getMinutes();
  let second = today.getSeconds();
  const ampm = hour >= 12 ? 'PM' : 'AM';

  // 12μ‹œκ°„μ œλ‘œ λ³€κ²½
  hour %= 12;
  hour = hour || 12; // hourκ°€ 0이면 12λ₯Ό μž¬ν• λ‹Ή

  // 10미만인 λΆ„κ³Ό 초λ₯Ό 2자리둜 λ³€κ²½
  minute = minute < 10 ? '0' + minute : minute;
  second = second < 10 ? '0' + second : second;

  const now = `${year}λ…„ ${month}μ›” ${date}일 ${day} ${hour}:${minute}:${second} ${ampm}`;

  console.log(now);

  // 1μ΄ˆλ§ˆλ‹€ printNow ν•¨μˆ˜λ₯Ό μž¬κ·€ ν˜ΈμΆœν•œλ‹€. 41.2.1절 "setTimeout / clearTimeout" μ°Έκ³ 
  setTimeout(printNow, 1000);
}());
profile
μ΄μ‚¬μ€‘μž…λ‹ˆλ‹€!🌟https://velog.io/@devkyoung2

0개의 λŒ“κΈ€

κ΄€λ ¨ μ±„μš© 정보