2015-04-06 8 views

Odpowiedz

24

ten powinien zrobić:

var dateStart = moment('2013-8-31'); 
var dateEnd = moment('2015-3-30'); 
var timeValues = []; 

while (dateEnd > dateStart || dateStart.format('M') === dateEnd.format('M')) { 
    timeValues.push(dateStart.format('YYYY-MM')); 
    dateStart.add(1,'month'); 
} 
+2

jeśli wybierzesz zakres dat podobny do - 2016-08-16 do 2017-02-15, sama ta logika nie będzie pomocna . Ponieważ "luty 2017" nie zostanie dodany. Po prostu dlatego, że w ostatniej iteracji zaczyna się data 2017-02-16, czyli jest większa niż 2017-02-15 –

+1

Korekta Alexandra Swanna (poniżej) jest najlepszą odpowiedzią i rozwiązuje ten problem z brakującego miesiąca końcowego. – LStarky

+0

korekta dodana do mojej odpowiedzi ... faktycznie chciałem usunąć to tak, że stały pozostaje, ale moja odpowiedź musi mieć "akceptowane" usunięte – vinjenzo

1

można spróbować z tego przykładu

var one = moment("2015-3-30"); 
    var two = moment("2014-8-31"); 
    var dateDiffs = []; 
    var count = Math.round(moment.duration(one.diff(two)).asMonths()); 

    month = two.month() + 1; 
    year = two.year(); 

    for (var i=1; i<=count; i++) { 
     if (month > 12) { 
     month = 1; 
     year++; 
     } 
     dateDiffs.push(year+"-"+month); 
     console.log(month); 
     month++; 
    } 

    console.log(dateDiffs); 
+0

dzięki za odpowiedź, ale kod ma pewne problemy, jeśli datediffs jest więcej niż 2 lata, można sprawdzić to skrzypce: https://jsfiddle.net/jcoyace0/ –

+0

dzięki za pomoc, to działa dobrze w chrome, ale mam nieprawidłową datę w Firefoksie, szukam rozwiązania tego błędu –

3

używasz wielu formatów na wyjściu: rrrr-mm i YYYY-M, więc wybrałem pierwszy. Możesz edytować według własnego uznania.

var startDateString = "2012-5-30"; 
 
var endDateString = "2015-8-31"; 
 
var startDate = moment(startDateString, "YYYY-M-DD"); 
 
var endDate = moment(endDateString, "YYYY-M-DD").endOf("month"); 
 

 
var allMonthsInPeriod = []; 
 

 
while (startDate.isBefore(endDate)) { 
 
    allMonthsInPeriod.push(startDate.format("YYYY-MM")); 
 
    startDate = startDate.add(1, "month"); 
 
}; 
 

 
console.log(allMonthsInPeriod); 
 

 
document.getElementById("result").innerHTML = allMonthsInPeriod.join("<br />");
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.19.4/moment.min.js"></script> 
 
<div id="result"></div>

8

myślę oryginalna odpowiedź nie jest do końca poprawne, ponieważ nie dostanie '2015-3' w swojej tablicy. Wynika to z faktu, że twoja data początkowa ostatecznie zakończy się jako '2015-3-31' i zawiedzie warunkową. Możesz go rozszerzyć jak poniżej.

var dateStart = moment('2013-8-31'); 
var dateEnd = moment('2015-3-30'); 
var timeValues = []; 

while (dateEnd > dateStart || dateStart.format('M') === dateEnd.format('M')) { 
    timeValues.push(dateStart.format('YYYY-MM')); 
    dateStart.add(1,'month'); 
} 
+1

To jest idealne rozwiązanie dla "co z ostatnim miesiącem? " problem z pierwotnie przyjętą odpowiedzią. Dziękujemy za dodanie! Ten powinien otrzymać najbardziej upvotes. – LStarky

Powiązane problemy