39

如何使用 javascript 获取当前季度?我正在尝试检测我们目前处于哪个季度,例如 2。

编辑我如何计算本季度剩余的天数?

4

11 回答 11

82

假设一月到三月被认为是第一季度(一些国家/公司将其财政年度与日历年分开),以下代码应该有效:

var today = new Date();
var quarter = Math.floor((today.getMonth() + 3) / 3);

这给了你:

Month      getMonth()  quarter
---------  ----------  -------
January         0         1
February        1         1
March           2         1
April           3         2
May             4         2
June            5         2
July            6         3
August          7         3
September       8         3
October         9         4
November       10         4
December       11         4

至于如何获得该季度剩余的天数,基本上是计算出下一季度的第一天并计算出差异,例如:

var today = new Date();
var quarter = Math.floor((today.getMonth() + 3) / 3);
var nextq;
if (quarter == 4) {
    nextq = new Date (today.getFullYear() + 1, 1, 1);
} else {
    nextq = new Date (today.getFullYear(), quarter * 3, 1);
}
var millis1 = today.getTime();
var millis2 = nextq.getTime();
var daydiff = (millis2 - millis1) / 1000 / 60 / 60 / 24;

这是未经检验的,但理论是合理的。基本上创建下一个季度对应的日期,把它和今天转换成从纪元开始算起的毫秒数,那么差就是毫秒数。

将其除以一天中的毫秒数,您就会得到天数的差异。

这给了你(至少大致)本季度剩余的天数。您可能需要对其进行微调,以确保所有时间都设置为相同的值 (00:00:00),以便精确到天数。

根据您对“本季度剩余天数”的实际定义,它也可能减一。

但这应该是一个很好的起点。

于 2012-08-16T06:16:33.300 回答
46

鉴于您没有提供任何标准来确定“*我们目前所处的季度”,因此可以建议您使用一种算法,然后您必须适应您需要的任何标准。例如

// For the US Government fiscal year
// Oct-Dec = 1
// Jan-Mar = 2
// Apr-Jun = 3
// Jul-Sep = 4
function getQuarter(d) {
  d = d || new Date();
  var m = Math.floor(d.getMonth()/3) + 2;
  return m > 4? m - 4 : m;
}

作为一个可运行的片段并包括年份:

function getQuarter(d) {
  d = d || new Date();
  var m = Math.floor(d.getMonth() / 3) + 2;
  m -= m > 4 ? 4 : 0;
  var y = d.getFullYear() + (m == 1? 1 : 0);
  return [y,m];
}

console.log(`The current US fiscal quarter is ${getQuarter().join('Q')}`);
console.log(`1 July 2018 is ${getQuarter(new Date(2018,6,1)).join('Q')}`);

然后,您可以酌情将其调整到各个财务或日历季度。你也可以这样做:

function getQuarter(d) {
  d = d || new Date(); // If no date supplied, use today
  var q = [4,1,2,3];
  return q[Math.floor(d.getMonth() / 3)];
}

然后q根据所需季度的定义使用不同的数组。

编辑

如果从 1 月 1 日、4 月、7 月和 10 月 1 日开始,以下是一个季度的剩余天数,它在各种浏览器中进行了测试,包括 IE 6(尽管因为它使用基本的 ECMAScript,所以它应该可以在任何地方工作):

function daysLeftInQuarter(d) {
  d = d || new Date();
  var qEnd = new Date(d);
  qEnd.setMonth(qEnd.getMonth() + 3 - qEnd.getMonth() % 3, 0);
  return Math.floor((qEnd - d) / 8.64e7);
}
于 2012-08-16T06:28:17.673 回答
7

如果第一个解决方案不起作用,您可以将其调整到您想要的范围

var today = new Date();
var month = now.getMonth();
var quarter;
if (month < 4)
  quarter = 1;
else if (month < 7)
  quarter = 2;
else if (month < 10)
  quarter = 3;
else if (month < 13)
  quarter = 4;
于 2012-08-16T06:41:02.403 回答
6
function getQuarter(d) {
  return Math.floor(d.getMonth()/3) + 1);
}

编辑:我遗漏了 %4,完全正确,谢谢克莱门特

于 2019-06-28T12:33:23.013 回答
4

您可以使用moment包:

使用 moment 包对您的问题的回答是:

moment().quarter()

以下是使用 moment 包的季度的开始和结束日期:

季度开始日期

moment().quarter(moment().quarter()).startOf('quarter');

将返回当前季度,并将日期设置为季度开始日期。

moment("2019", "YYYY").quarter(4).startOf('quarter');

将返回“2019”年第四季度的开始日期。

moment().startOf('quarter');

将返回当年当前季度的开始日期。

季度结束日期

moment().quarter(moment().quarter()).endOf('quarter');

将返回当前季度,并将日期设置为季度结束日期。

moment("2019", "YYYY").quarter(4).endOf('quarter');

将返回“2019”年第四季度的结束日期。

moment().endOf('quarter');

将返回当年当前季度的结束日期。

于 2020-07-21T08:37:28.017 回答
3

取决于月份

 var date = new Date();     
 var quarter =  parseInt(date.getMonth() / 3 ) + 1 ;

取决于日期

 var date = new Date();    
 var firstday = new Date(date.getFullYear(),0,1); // XXXX/01/01
 var diff = Math.ceil((date - firstday) / 86400000); 
 // a quarter is about 365/4 
 quarter =  parseInt( diff / ( 365/ 4 )) + 1 
 // if today is 2012/01/01, the value of quarter  is  1.
于 2012-08-16T06:02:09.983 回答
3

这对我有用!

var d = new Date();
var quarter = Math.ceil(d.getMonth() / 3);

console.log(quarter)

于 2018-08-01T09:30:33.990 回答
0

它效率不高或不可读,但它具有单线风格。

(new Date(new Date().getFullYear(), Math.floor((new Date().getMonth() + 3) / 3) * 3, 1) - new Date()) / 86400000
于 2014-07-04T17:01:54.317 回答
0
// Set Period Function
  SetPeriod(SelectedVal) {
    try {
      if (SelectedVal === '0') { return; }
      if (SelectedVal != null) {
        let yrf: number, mtf: number, dyf: number, yrt: number, mtt: number, dyt: number, dtf: any, dtt: any;
        let dat = new Date();
        let q = 0;
        switch (SelectedVal) {
          case '-1': // Not specify
            frm = ''; to = '';
            return;
          case '0': // As specify
            break;
          case '1': // This Month
            yrf = yrt = dat.getUTCFullYear();
            mtf = mtt = dat.getUTCMonth();
            dyf = 1; dyt = this.getDaysInMonth(mtf, yrf);
            break;
          case '2': // Last Month
            dat.setDate(0); // 0 will result in the last day of the previous month
            dat.setDate(1); // 1 will result in the first day of the month
            yrf = yrt = dat.getUTCFullYear();
            mtf = mtt = dat.getUTCMonth();
            dyf = 1; dyt = this.getDaysInMonth(mtf, yrf);
            break;
          case '3': // This quater
            q = Math.ceil((dat.getUTCMonth()) / 3);
          // tslint:disable-next-line:no-switch-case-fall-through
          case '4': // Last quater
            if (q === 0) { q = Math.ceil(dat.getUTCMonth() / 3) - 1; if (q === 0) { q = 1; } }
            yrf = yrt = dat.getUTCFullYear();
            if (q === 1) {
              mtf = 0; mtt = 2;
              dyf = 1; dyt = 31;
            } else if (q === 2) {
              mtf = 3; mtt = 5;
              dyf = 1; dyt = 30;
            } else if (q === 3) {
              mtf = 6; mtt = 8;
              dyf = 1; dyt = 30;
            } else if (q === 4) {
              mtf = 9; mtt = 11;
              dyf = 1; dyt = 31;
            }
            break;
          case '6': // Last year
            dat = new Date(dat.getUTCFullYear(), 0, 1);
          // tslint:disable-next-line:no-switch-case-fall-through
          case '5': // This year
            yrf = yrt = dat.getUTCFullYear();
            mtf = 0; mtt = 11;
            dyf = 1; dyt = 31;
            break;
        }

        // Convert to new Date
        dtf = new Date(yrf, mtf, dyf);
        dtt = new Date(yrt, mtt, dyt);
        console.log('dtf', dtf);
        console.log('dtt', dtt);

      }
    } catch (e) {
      alert(e);
    }
  }



// Get Day in Month
  getDaysInMonth = (month: number, year: number) => {
    return new Date(year, month + 1, 0).getDate();
  }
于 2019-11-15T02:42:25.240 回答
0

就我而言,季度取决于输入季度开始日期(月、日)和季度持续时间(3、6)

function getCurrentQuarter(startDateString, quarterDuration) {
    var startDate = new Date(startDateString)
    // default order of months
    var months = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]
    let startMonth = startDate.getMonth() + 1
    let startMonthIndex = months.indexOf(startMonth)
    // rotate months to get start month first
    if (startMonthIndex != 0) {
        var monthsNew = months.slice(startMonthIndex, months.length)
        months = monthsNew.concat(months.slice(0, startMonthIndex))
    }
    
    let today = new Date()
    let thisMonth = today.getMonth() + 1
    let thisMonthIndex = months.indexOf(thisMonth) + 1
    // compare with date
    let thisDay = today.getDate()
    let startDay = startDate.getDate()
    if (thisDay < startDay) {
        // this is previous month
        if (thisMonthIndex == 1) {
            thisMonthIndex = 12
        } else {
            thisMonthIndex = thisMonthIndex - 1
        }
    }
    // find quarter
    let thisQuarter = Math.ceil(thisMonthIndex / quarterDuration)

    return thisQuarter
}

getCurrentQuarter('2021-03-15', 3)

于 2021-03-02T07:47:40.893 回答
-1

这是我的看法

var todayDate = new Date(new Date().setUTCHours(0, 0, 0, 0));
var currentQuarter = Math.floor(todayDate.getMonth() / 3);
var firstDate = new Date(
  new Date(todayDate.getFullYear(), currentQuarter * 3, 1).setUTCHours(0, 0, 0, 0)
);
var endDate = new Date(
  new Date(
    firstDate.getFullYear(),
    firstDate.getMonth() + 3,
    0
  ).setUTCHours(0, 0, 0, 0)
);
console.log(endDate)

于 2021-05-25T09:21:38.897 回答