Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/385.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何使用Moment.js获取一个月内的天数列表_Javascript_Node.js_Momentjs - Fatal编程技术网

Javascript 如何使用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

使用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-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');
    });
}