답변:
하루를 추가하면 필요한 경우 날짜가 다음 달로 롤오버되고 밀리 초 단위로 엉망이되는 방법을 사용하여이를 수행하는 방법이 있습니다. 일광 절약 시간도 문제가되지 않습니다.
var now = new Date();
var daysOfYear = [];
for (var d = new Date(2012, 0, 1); d <= now; d.setDate(d.getDate() + 1)) {
daysOfYear.push(new Date(d));
}
날짜를 저장하려면 위와 같이 날짜를 새로 작성해야합니다. new Date(d)
그렇지 않으면 모든 저장된 날짜가 d
루프에서 최종 값이 됩니다.
Date.now()
정의 할 때 왜합니까 now
? new Date()
기본적으로 현재 날짜를 객체로 반환합니다 . 생성자를 사용 Date
하지 않고 호출 new
하면 Date 문자열을 제공하여 Date 객체로 변환합니까?
new Date(2012, 0, 1);
위해 잘못된 하루 (하루 전)를 집어 들었 습니다 new Date(Date.UTC(2012, 0, 1))
.
Tom Gullen의 답변을 기반으로합니다.
var start = new Date("02/05/2013");
var end = new Date("02/10/2013");
var loop = new Date(start);
while(loop <= end){
alert(loop);
var newDate = loop.setDate(loop.getDate() + 1);
loop = new Date(newDate);
}
Date
글로벌 객체입니다 developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/...
startDate와 endDate가 실제로 날짜 객체 인 경우 1970 년 1 월 1 일 자정 이후 다음과 같이 밀리 초 단위로 변환 할 수 있습니다.
var startTime = startDate.getTime(), endTime = endDate.getTime();
그런 다음 1에서 다른 증분 loopTime으로 86400000 (1000 * 60 * 60 * 24)까지 루프 할 수 있습니다-하루의 밀리 초 수 :
for(loopTime = startTime; loopTime < endTime; loopTime += 86400000)
{
var loopDay=new Date(loopTime)
//use loopDay as you wish
}
86400000
하루에 몇 초가 있다고 가정 할 수 없습니다 . 이 루프는 일광 절약 시간제 변경 및 기타 경계 조건에 취약합니다.
Moment.js 를 사용할 수 있다면 더 간단한 답변을 찾았 습니다 .
// cycle through last five days, today included
// you could also cycle through any dates you want, mostly for
// making this snippet not time aware
const currentMoment = moment().subtract(4, 'days');
const endMoment = moment().add(1, 'days');
while (currentMoment.isBefore(endMoment, 'day')) {
console.log(`Loop at ${currentMoment.format('YYYY-MM-DD')}`);
currentMoment.add(1, 'days');
}
<script src="https://cdn.jsdelivr.net/npm/moment@2/moment.min.js"></script>
var start = new Date("2014-05-01"); //yyyy-mm-dd
var end = new Date("2014-05-05"); //yyyy-mm-dd
while(start <= end){
var mm = ((start.getMonth()+1)>=10)?(start.getMonth()+1):'0'+(start.getMonth()+1);
var dd = ((start.getDate())>=10)? (start.getDate()) : '0' + (start.getDate());
var yyyy = start.getFullYear();
var date = dd+"/"+mm+"/"+yyyy; //yyyy-mm-dd
alert(date);
start = new Date(start.setDate(start.getDate() + 1)); //date increase by 1
}
Tabare의 답변을 바탕으로주기가 끝나기 때문에 마지막 날에 하루를 더 추가해야했습니다.
var start = new Date("02/05/2013");
var end = new Date("02/10/2013");
var newend = end.setDate(end.getDate()+1);
var end = new Date(newend);
while(start < end){
alert(start);
var newDate = start.setDate(start.getDate() + 1);
start = new Date(newDate);
}
밀리 초로 효율적인 방법을 원한다면 :
var daysOfYear = [];
for (var d = begin; d <= end; d = d + 86400000) {
daysOfYear.push(new Date(d));
}
UI에서 시작 날짜와 종료 날짜를 가져 와서 컨트롤러의 범위 변수에 저장했다고 가정 해 봅시다.
그런 다음 모든 함수 호출에서 재설정 될 배열을 선언하여 함수에 대한 다음 호출에서 새 데이터를 저장할 수 있습니다.
var dayLabel = [];
새 날짜 를 사용 하지 않고 변수에 직접 할당하면 setDate 함수가 각 반복에서 원래 변수 값을 변경하므로 새 날짜 (시작 변수)를 사용해야합니다.
for (var d = new Date($scope.startDate); d <= $scope.endDate; d.setDate(d.getDate() + 1)) {
dayLabel.push(new Date(d));
}
Jayarjo의 답변을 바탕으로 :
var loopDate = new Date();
loopDate.setTime(datFrom.valueOf());
while (loopDate.valueOf() < datTo.valueOf() + 86400000) {
alert(loopDay);
loopDate.setTime(loopDate.valueOf() + 86400000);
}