시간이 중요한 역할을 하는 경우 JavaScript에서 날짜를 비교하는 작업이 어려울 수 있습니다. 이 문제를 해결하기 위해 개발자는 시간을 무시하고 날짜 구성 요소에만 집중하는 간단한 접근 방식을 사용할 수 있습니다. 그러나 이를 효과적으로 달성하려면 Date 객체의 복잡성에 대한 미묘한 이해가 필요합니다.
문제 이해
보다 큼 연산자( >). 다음 코드 조각을 고려하십시오.
const now = new Date(); const input = $('datum').getValue(); const dateArray = input.split('/'); const userMonth = parseInt(dateArray[1]) - 1; const userDate = new Date(); userDate.setFullYear(dateArray[2], userMonth, dateArray[0], now.getHours(), now.getMinutes(), now.getSeconds(), now.getMilliseconds()); if (userDate > now) { alert(now + '\n' + userDate); }
이 코드에서 userDate는 현재 시간으로 구성되므로 현재 날짜와 비교할 때 거짓 부정이 발생할 수 있습니다. 이 문제를 해결하려면 시간 구성 요소에서 날짜 측면을 분리해야 합니다.
시간을 0으로 설정
시간의 영향을 제거하기 위해 setHours 메서드를 사용합니다. 날짜 객체의 시, 분, 초, 밀리초를 0으로 설정하면 날짜를 가장 순수한 형식으로 효과적으로 잘라낼 수 있습니다.
date1.setHours(0, 0, 0, 0);
비교 단순성
시간과 함께 구성 요소가 무효화되면 날짜를 비교하는 작업이 훨씬 더 간단해집니다. 다음 코드는 이를 보여줍니다.
date1 = new Date(); date2 = new Date(2011, 8, 20); date1.setHours(0, 0, 0, 0); if (date1 > date2) { // Logic for dates only }
이제 날짜는 일, 월, 연도만을 기준으로 평가되므로 시간의 혼란 요인 없이 정확한 비교가 보장됩니다. 이 기술은 JavaScript에서 날짜 차이를 식별하는 강력하고 안정적인 수단을 제공합니다.
위 내용은 JavaScript에서 정확한 날짜 비교를 보장하는 방법: 시간대가 결과에 영향을 줍니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!