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;
}
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? –
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
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. –