Javascript 如何使用Moment.js获取一个月内的天数列表
使用Moment.js,我希望在数组中获得特定年份的一个月内的所有天。例如:Javascript 如何使用Moment.js获取一个月内的天数列表,javascript,node.js,momentjs,Javascript,Node.js,Momentjs,使用Moment.js,我希望在数组中获得特定年份的一个月内的所有天。例如: January-2014: [ "01-wed", "02-thr", "03-fri", "04-sat" ] js> getDaysArray(2012,2) ["1-wed", "2-thu", "3-fri", "4-sat", "5-sun", "6-mon", "7-tu
January-2014:
[
"01-wed",
"02-thr",
"03-fri",
"04-sat"
]
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"]
有什么建议吗?我查看了Moment.js文档,但没有找到任何内容。我得到的壁橱是:
moment("2012-02", "YYYY-MM").daysInMonth()
但这只返回一个整数,其中包含特定月份的总天数,而不是一个数组,其中包含每天的天数。这里有一个函数可以实现这一点(不使用矩,只使用普通JavaScript): 例如:
January-2014:
[
"01-wed",
"02-thr",
"03-fri",
"04-sat"
]
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+版本:
const getDaysArray = (year, month) => {
const monthIndex = month - 1
const names = Object.freeze(
[ 'sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat' ]);
const date = new Date(year, monthIndex, 1);
const result = [];
while (date.getMonth() == monthIndex) {
result.push(`${date.getDate()}-${names[date.getDay()]}`);
date.setDate(date.getDate() + 1);
}
return result;
}
作为旁注,您可以看到,声明日期const
不会阻止我们对其进行变异(用于使工作日名称数组不可变的Object.freeze
,也不会对日期执行任何操作)。我们在这里利用了可变性,但如果我们真的想要一个不可变的日期,而语言在当前Javascript中强制实现了这种不可变性,我们就必须这样做
另外请注意,与问题中包含的示例输出不同,上述解决方案不会在10号之前将pad日期归零。使用ES2017+可以很容易地修复:
result.push(`${date.getDate()}`.padStart(2,'0') + `-${names[date.getDay()]}`);
在旧版本的JS中这样做需要滚动您自己的零填充逻辑,这并不难,但也不是问题的焦点。momentjs的替代方案,为我工作
function getDaysArrayByMonth() {
var daysInMonth = moment().daysInMonth();
var arrDays = [];
while(daysInMonth) {
var current = moment().date(daysInMonth);
arrDays.push(current);
daysInMonth--;
}
return arrDays;
}
你可以查一下
var schedule = getDaysArrayByMonth();
schedule.forEach(function(item) {
console.log(item.format("DD/MM"));
});
您可以使用
lodash
中的.times
帮助程序,并在下面这样的时刻使用:
var daysInMonth=[];
var monthDate=moment().startOf('month');//更改为利息月份中的日期
_.times(monthDate.daysInMonth(),函数(n){
daysInMonth.push(monthDate.format('DD-ddd');//您的格式
月日。添加(1,“日”);
});
console.log(daysInMonth)
从moment.js 2.1.0版开始,设置如下日期:
moment([2012, 0, 31]).month(1).format("YYYY-MM-DD"); // 2012-02-29
然后,您只需解析日期,就可以得到一个月的天数。或者,您现在可以使用以下方法来实现此目的:
const month = moment('2012-02', 'YYYY-MM');
const range = moment().range(moment(month).startOf('month'), moment(month).endOf('month'));
const days = range.by('days');
console.log([...days].map(date => date.format('DD-ddd')));
以下是两种很好的功能性方法,除了矩之外没有外部依赖性:
const currentMonthDates = new Array(moment().daysInMonth()).fill(null).map((x, i) => moment().startOf('month').add(i, 'days'));
const currentMonthDates = Array.from({length: moment().daysInMonth()}, (x, i) => moment().startOf('month').add(i, 'days'));
这将返回一个矩对象数组,然后您可以在其上运行所需的任何format方法
为了进一步阅读,还请注意,在第一个示例中,在映射到数组之前,您必须使用null填充数组,因为在进行映射之前,数组仍然被分类为空,因此映射函数将不会运行。要使用矩量.js获取一个月内的天数,我使用以下方法:
function daysInMonth(month) {
var count = moment().month(month).daysInMonth();
var days = [];
for (var i = 1; i < count+1; i++) {
days.push(moment().month(month).date(i));
}
return days;
}
来到这篇文章,我做了一个日期选择器(是的…)-我用了一个类似的方法来回答上面的问题,但我认为for循环更直观/可读。这确实使用了基于JS0的日期,所以5=6月,1=2月,等等-对于基于1的日期,您可以在日期中省略“+1”
var getDaysInMonth = function(year, month) {
var names = [ 'sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat' ];
var date = new Date(year, month + 1, 0);
var days = date.getDate();
var dayList = [];
for (i = days; days > 0; days--) {
date.setDate(date.getDate() + 1);
dayList.push((dayList.length + 1) + '-' + names[date.getDay()]);
}
return dayList;
}
我认为使用该方法来获得一个月的天数,并生成数组是更干净、更高效的方法
const getDaysByMonth=(月)=>{
const daysInMonth=时刻(月)。daysInMonth();
返回数组。from({length:daysInMonth},(v,k)=>k+1)
};
月份='2019-02';
log(`二月=>${getDaysByMonth(月)}`);
月份='2019-06';
log(`June=>${getDaysByMonth(month)}`);
月份='2019-07';
log(`July=>${getDaysByMonth(month)}`)代码>
您可以使用for loop with moment来完成
var daysInMonth=[];
var monthDate=moment().startOf('month');
对于(假设i=0;iI假设应该是“04 sat”
,而不是“04 say”
,然后是“05 sun”、“06 mon”、“07 tue”、“08 wed”
等等?你为什么需要这个?是的,say是一个打字错误。我需要在下拉列表中显示它,以便用户可以选择一年,然后是一个月,然后是年-月组合中的一天。但是,与其显示1,2,3…对于这些天,我还想显示日期名称1-mon,2-tues,3-wed…请参见下面的答案。为了便于有人选择虽然是一个日期,但我建议使用众多可用的JavaScript日历日期选择器中的一个。我将使用日期选择器处理我正在使用的日历插件中的其他内容,但对于应用程序的这一特定部分,它需要是一个下拉列表。感谢您的回答。也许您可以改用它,daysInMonth.push(monthDate.format('DD-ddd');
要获得正确的预期formatproperty范围,类型'Moment'@Ahmed上不存在,您必须在代码中安装所有range Moment包并扩展它:@AntoineRucquoy,这是我已经做过的。感谢您的帮助!您的代码仅适用于当前日期,例如,如果我传递了格式的话“'2020-01','YYYY-MM',日期不计算right@RavenTheX您可以传入任何日期,只需将矩()的实例替换为矩(日期,格式)。您的格式必须包含一天(而不是YYYY-MM)否则,您没有添加日期的起始点。如果您对日期进行硬编码,则始终可以将其设置为所需月份的第一个,并忽略.startOf(月份)调用。您可以解释代码中的什么是const addDays吗?mDate最初有一个月的第一天。因此const addDays表示从第二次迭代开始增加一天。
function getAllDatesOfMonth(date) {
const mDate = moment(date, "YYYY-MM");
const daysCount = mDate.daysInMonth();
return Array(daysCount).fill(null).map((v,index)=>{
const addDays = index === 0 ? 0 : 1;
return mDate.add(addDays, 'days').format('YYYY-MM-DD');
});
}