2014-08-31 5 views
13

Verwenden von Moment.js Ich möchte alle Tage in einem Monat eines bestimmten Jahres in einem Array abrufen. Zum Beispiel:So erhalten Sie die Liste der Tage in einem Monat mit Moment.js

January-2014: 
[ 
"01-wed", 
"02-thr", 
"03-fri", 
"04-sat" 
] 

irgendwelche Vorschläge? Ich habe die Dokumentation von Moment.js durchgesehen, konnte aber nichts finden. Der Schrank ich erhielt, war diese:

moment("2012-02", "YYYY-MM").daysInMonth() 

Aber dies nur ein int mit insgesamt Tagen bestimmten Monat nicht wieder ein Array mit jedem Tag.

+0

Ich nehme an, dass sollte "04-sat" statt "04-say" sein, gefolgt von "05-sun", "06-mon", "07-tue", "08- wed "' und so weiter? Warum brauchst du das? –

+0

Ja, sagen war ein Tippfehler. Ich brauche das, um in einem Dropdown anzuzeigen, also kann Benutzer ein Jahr dann Monat wählen dann einen Tag innerhalb der Jahr-Monat Verbindung. Aber anstatt 1,2,3 zu zeigen ... für die Tage möchte ich auch den Tag Namen 1-mon, 2-tues, 3-wed ... zeigen – ecorvo

+0

Siehe meine Antwort unten. Für den Zweck, jemanden ein Datum auswählen zu lassen, würde ich jedoch empfehlen, einen der vielen verfügbaren Kalendereinträge für JavaScript-Kalender zu verwenden. –

Antwort

27

Hier ist eine Funktion, die den Trick tun wird (nicht mit Moment, aber nur Vanille JavaScript):

var getDaysArray = function(year, month) { 
    var names = [ 'sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat' ]; 
    var date = new Date(year, month - 1, 1); 
    var result = []; 
    while (date.getMonth() == month - 1) { 
    result.push(date.getDate() + "-" + names[date.getDay()]); 
    date.setDate(date.getDate() + 1); 
    } 
    return result; 
} 

Zum Beispiel:

js> getDaysArray(2012,2) 
["1-wed", "2-thu", "3-fri", "4-sat", "5-sun", "6-mon", "7-tue", 
"8-wed", "9-thu", "10-fri", "11-sat", "12-sun", "13-mon", "14-tue", 
"15-wed", "16-thu", "17-fri", "18-sat", "19-sun", "20-mon", "21-tue", 
"22-wed", "23-thu", "24-fri", "25-sat", "26-sun", "27-mon", "28-tue", 
"29-wed"] 

ES2015 + Version:

const getDaysArray = (year, month) => { 
    const names = Object.freeze(
    [ 'sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat' ]); 
    const date = new Date(year, month - 1, 1); 
    const result = []; 
    while (date.getMonth() == month - 1) { 
    result.push(`${date.getDate()}-${names[date.getDay()]}`); 
    date.setDate(date.getDate() + 1); 
    } 
    return result; 
} 
+0

Danke! Keine Notwendigkeit für einen Moment, solange es den Job macht :) – ecorvo

+0

es funktioniert perfekt. Danke – anhnt

4

Alternative mit momentjs, arbeitet für mich

function getDaysArrayByMonth() { 
    var daysInMonth = moment().daysInMonth(); 
    var arrDays = []; 

    while(daysInMonth) { 
    var current = moment().date(daysInMonth); 
    arrDays.push(current); 
    daysInMonth--; 
    } 

    return arrDays; 
} 

Und Sie können überprüfen

var schedule = getDaysArrayByMonth(); 
schedule.forEach(function(item) { 
    console.log(item.format("DD/MM")); 
}); 
7

Verwendung auch lodash_.times:

var daysInMonth = []; 

var monthDate = moment().startOf('month'); // change to a date in the month of interest 

_.times(monthDate.daysInMonth(), function (n) { 
    daysInMonth.push(monthDate.format('D')); // your format 
    monthDate.add(1, 'day'); 
}); 
-3

Ab moment.js Version 2.1.0, wenn Sie ein Datum wie eingestellt:

moment([2012, 0, 31]).month(1).format("YYYY-MM-DD"); // 2012-02-29 

Dann müssen Sie nur das Datum und yo analysieren Du hast die Anzahl der Tage in einem Monat.