概要
探してもあまり見つからなかったので自分で実装することにしました。
startDateとEndDateの値を変えれば動くようになってるはずです。
準備
moment.jsが必要です。
npmまたはyarnでライブラリを導入できる場合は以下のどちらかのコマンドを使ってインストールしてください。
npm i moment
yarn add moment
コード(古い版)
こちらのコードはやたら長い上に上位互換のものがあるので次の見出しにあるコードを使ったほうが見た目いいです。
const moment = require('moment');
function loopYmd(startDate, endDate){
const start = moment(startDate);
const end = moment(endDate);
let s = {
year: start.get('year'),
month: start.get('month') + 1,
day: start.get('date'),
};
let e = {
year: end.get('year'),
month: end.get('month') + 1,
day: end.get('date'),
};
for (let y = s.year; y <= e.year; y++) {
const isStartYear = y === s.year;
const isEndYear = y === e.year;
const startMonth = isStartYear ? s.month : 1;
const endMonth = isEndYear ? e.month : 12;
console.log(y + '年');
for (let m = startMonth; m <= endMonth; m++) {
const isStartMonth = m === s.month;
const isEndMonth = m === e.month;
const startDay = isStartYear && isStartMonth ? s.day : 1;
const endDay = isEndYear && isEndMonth ? e.day : getEndDay(y, m);
console.log(m + '月');
for (let d = startDay; d <= endDay; d++) {
console.log(d + '日');
}
}
}
}
function getEndDay(year, month) {
const date = String(year) + '-' + String(month);
return moment(date).endOf('month').get('date');
}
loopYmd('2017-12-01', new Date());
コード(短い最新版)
@myrさん ありがとうございます!
moment.jsに加算すれば全部回せるみたいです。
loopYmd.js
function loopYmd(startDate, endDate) {
let start = moment(startDate);
const end = moment(endDate);
while(start.unix() <= end.unix()) {
console.log(start.format('YYYY-MM-DD'));
start.add(1, 'days');
}
}
loopYmd('2017-12-01', new Date());
おわり
ググってもいい感じのコードがなくて自分で実装したので時間がかかりました
皆さんは僕のコードをコピペして時間を有効に使ってください
追記
頑張って時間かけて実装したらめっちゃ短く書けることが発覚しました
Qiitaに書いてなければ知ることはなかったと思うのでアウトプットしてよかったです