메뉴 건너뛰기

조회 수 2356 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

연도 더하기, 빼기

1년 후의 날짜, 1년 전의 날짜를 계산하기 위해서 getFullYear()와 setFullYear() 함수를 사용하였습니다.

date객체에서 getFullYear() 함수를 이용해서 연도를 추출한 후에,

해당 연도에 1을 더하거나 빼서 1년 후와 1년 전의 연도를 구하고,

그 값을 다시 setFullYear() 함수를 사용해서 원래의 Date객체의 연도를 변경해 주었습니다.

 

 

월 더하기, 빼기

연도 더하기 빼기와 마찬가지로,

1달 후, 1달 전의 날짜를 계산하기 위해 getMonth(), setMonth() 함수를 사용하였습니다.

 

그런데, 말일인 경우에 예상치 못한 결과가 나왔습니다.

1월 31일의 한 달 후 날짜가 3월 3일이라고 나왔습니다. 

아마 대부분 이런 경우 2월의 말일자인 2월 28일(또는 2월 29일, 윤달인 경우)이 나오는 것을 기대할 것입니다.

 

이런 결과가 나오는 경우는 2019년 1월 31일에 '월'의 숫자만 2월로 갈아 끼웠기 때문입니다.

그러면 2019년 2월 31일이 되는데, 사실 2월 31일은 없습니다. 2019년 2월의 마지막 날은 28일입니다.

그래서, 브라우저는 31-28=3,을 적용하여 3월 3일이라고 표시해 주는 것입니다.

 

우리가 원하는 결과대로 1월 31일의 한 달 후 날짜는 2월 28일이라는 결과를 얻기 위해서는

말일자를 보정하는 로직을 추가로 넣어주어야 합니다.

이 로직에 관해서는 다른 포스팅에서 다루도록 하겠습니다.

 

위와 같은 현상의 윤년인 해의 2월 29일에서 1년을 더하거나, 뺄 때도 발생할 것입니다.

즉, 2020년 2월 29일의 1년 후는 2021년 3월 1일이 될 것입니다.

이 부분에 대해서도 별도의 로직을 추가해 주어야 합니다.

이 부분도 다른 별도의 포스팅에서 다루도록 하겠습니다.

 

 

 

 

 

일자 더하기, 빼기

연도 계산, 월 계산과 마찬가지로 setDate(), getDate() 함수를 이용하여 

어제와 내일 날짜를 계산하였습니다.


 


List of Articles
번호 제목 날짜 조회 수
247 활용예제 : 체크박스 전체선택 전체해제 /라디오버튼 2014.03.01 7020
246 현재시간 기준 날짜 계산 2016.09.21 6103
245 현재 날짜, 시간 ( Month + 1 에 대해서 ) 2021.03.25 218
244 핸드폰 번호 일부 마스킹크 작업 (정규식 이용) 2015.06.19 10741
243 해상도에 따라 배경 바꾸기 2014.03.01 6083
242 함수의 arguments 를 이름(key)으로 접근하기 2016.09.21 5976
241 한글 짜르기 2019.01.16 1179
240 한글 또는 영문만이 존재하는지 체크 2019.01.16 1163
239 풍선도움말 2019.01.16 1167
238 폼안에 태그명, 함수명 같을때 오류 2021.03.26 214
237 페이지 이동 2021.03.26 190
236 페이지 로드 할때 컨트롤에 포커스 주기 2015.02.03 8500
235 패스워드, 확인패스워드가 맞는지 체크 2023.01.12 129
234 팝업창 차단 "허용 메시지" 2018.09.28 1738
233 팝업창 맨위로 올라오게 하기 2021.03.26 867
232 팝업창 가운데 띄우기 2016.12.23 6705
231 특정부위 마우스 오버시 설명을 보여주는 소스 2014.03.17 8695
230 특정 부분 인쇄 자바스크립트 2019.01.16 1588
229 특정 HTML DOM 엘레멘트로 스크롤 이동하기 2016.09.09 7075
228 텍스트박스(input type = "text") 숫자 증가, 감소 시키기 - 쇼핑몰 주문 수량 file 2015.06.19 12283
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 13 Next
/ 13

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved