通过Javascript获取上个季度和本季度的日期

时间:2012-03-23 14:02:14

标签: javascript html

我正在尝试创建一个报告,需要通过Javascript获取上一季度和本季度的日期。该代码在上个月工作,但在3月它不起作用。它显示了本季度的最后一个季度,本季度显示为下个季度。我在这个项目中使用datejs。这是我正在使用的代码:

function thisQuarterDates(from, to) {
    var month = Date.parse('today').toString('MM');
    var quarterMonth = (Math.floor(month/3)*3)+1;
    var year = Date.parse('today').toString('yyyy');

    var quarterStartDate = (quarterMonth < 10) ? quarterMonth+'/1/' +year : quarterMonth+'/1/'+ year;
    var quarterEndDate = Date.parse(quarterStartDate).add(2).months().moveToLastDayOfMonth().toString('M/d/yyyy');
    var today = Date.parse('today').toString('M/d/yyyy');

    document.getElementById(from).value = quarterStartDate;
    document.getElementById(to).value = quarterEndDate;
}


function lastQuarterDates(from, to) {
    var month = Date.parse('today').toString('MM');
    var quarter = (Math.floor(month/3))+1;
    var lastQuarter = (quarter > 1) ? quarter - 1 : lastQuarter = 4;
    var year;
    if (((((lastQuarter-1)*3)+1) < 10))
    {
        year = Date.parse('today').toString('yyyy');
    }
    else
    {
        year = Date.parse('today').add(-1).years().toString('yyyy');
    }
    var firstDate = ((((lastQuarter-1)*3)+1) < 10) ? (((lastQuarter-1)*3)+1) +'/1/'+ year : (((lastQuarter-1)*3)+1) +'/1/'+ year;
    var lastDate = Date.parse(firstDate).add(2).months().moveToLastDayOfMonth().toString('M/d/yyyy');

    document.getElementById(from).value = firstDate;
    document.getElementById(to).value = lastDate;
}

任何人都知道为什么它不正确或有更简单的方法吗?

8 个答案:

答案 0 :(得分:10)

如果您正在使用moment.js,这可能会更容易:

var quarterAdjustment= (moment().month() % 3) + 1;
var lastQuarterEndDate = moment().subtract({ months: quarterAdjustment }).endOf('month');
var lastQuarterStartDate = lastQuarterEndDate.clone().subtract({ months: 3 }).startOf('month');

转换为date.js应该相当容易。

答案 1 :(得分:3)

关于第一次功能改变

var quarterMonth = (Math.floor(month/3)*3)+1;

var quarterMonth = (Math.floor((month-1)/3)*3)+1;

和第二个功能

var quarter = (Math.floor(month/3))+1;

var quarter = (Math.floor((month-1)/3))+1;

我觉得没问题。

关于第二个功能,我没有看到

的意思
((((lastQuarter-1)*3)+1) < 10)

一个简单的

(lastQuarter < 4)

将做同样的工作

答案 2 :(得分:3)

使用 moment.js库,可以非常简单地获取特定季度的开始和结束日期,如下所示:

Start date of last quarter = moment().subtract(lastQuarterNumber, 'quarter').startOf('quarter');

End date of last quarter = moment().subtract(lastQuarterNumber, 'quarter').endOf('quarter');

Start date of current quarter = moment().startOf('quarter');

End date of current quarter = moment().endOf('quarter');

答案 3 :(得分:1)

使用 moment.js

  • 本季度开始时间:moment().startOf('quarter')
  • 本季度末:moment().endOf('quarter')
  • 上季度START:moment().subtract(1, 'quarter').startOf('quarter')
  • 上季度END:moment().subtract(1, 'quarter').endOf('quarter')
  • 下一季度START:moment().add(1, 'quarter').startOf('quarter')
  • 下一季度末:moment().add(1, 'quarter').endOf('quarter')

答案 4 :(得分:0)

使用这个简单的代码来获取基于1月和4月的所有季度

Demo

代码:

 // startMonth should be january or april

  function setQuarter(startMonth) {
    var obj = {};
    if(startMonth=='january'){

        obj.quarter1 = {start:moment().month(0).startOf('month'),end:moment().month(2).endOf('month')}
        obj.quarter2 = {start:moment().month(3).startOf('month'),end:moment().month(5).endOf('month')}
        obj.quarter3 = {start:moment().month(6).startOf('month'),end:moment().month(8).endOf('month')}
        obj.quarter4 = {start:moment().month(9).startOf('month'),end:moment().month(11).endOf('month')}
        console.log(obj);
        return obj;
    }
    else if(startMonth=='april'){

        obj.quarter1 = {start:moment().month(3).startOf('month'),end:moment().month(5).endOf('month')}
        obj.quarter2 = {start:moment().month(6).startOf('month'),end:moment().month(8).endOf('month')}
        obj.quarter3 = {start:moment().month(9).startOf('month'),end:moment().month(11).endOf('month')}
        obj.quarter4 = {start:moment().month(0).startOf('month').add('years',1),end:moment().month(2).endOf('month').add('years',1)}
        console.log(obj);
        return obj;
    }
}

 setQuarter('april');

Fiddle

答案 5 :(得分:0)

纯JS中的简单通用解决方案。
首先计算四分之一数

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

接下来,当前季度

const startFullQuarter = new Date(today.getFullYear(), quarter * 3, 1);
const endFullQuarter = new Date(startFullQuarter.getFullYear(), startFullQuarter.getMonth() + 3, 0);

上一季度

const startFullQuarter = new Date(today.getFullYear(), quarter * 3 - 3, 1);
const endFullQuarter = new Date(startFullQuarter.getFullYear(), startFullQuarter.getMonth() + 3, 0);

在表达式3's中每季度添加或减去new Date(today.getFullYear(), quarter * 3 - x, 1)以获得未来或过去的季度。

答案 6 :(得分:0)

我使用 date-fns 库已经有一段时间了。它公开的方法对于解决此类问题非常有用。

您可以使用 addQuartersubQuarter 方法。

代码看起来像:

    const lastQuarterStartDate = startOfQuarter(subQuarters(new Date(2014, 8, 1),1))

    const lastQuarterEndDate = lastDayOfQuarter(subQuarters(new Date(2014, 8, 1),1))

    const thisQuarterStartDate = startOfQuarter(new Date(2014, 8, 1))

    const thisQuarterEndDate = lastDayOfQuarter(new Date(2014, 8, 1))

参考:https://date-fns.org/v2.21.2/docs/addQuarters

答案 7 :(得分:-1)

使用它,我们可以动态获取季度的开始和结束日期,而不管财政年度(季度)的开始时间。

var fYearStart=new Date('2021-1-29') //Pass your financial year's start date
var q1Start=new Date(fYearStart.getFullYear(),fYearStart.getMonth(),1)
var dummy1=new Date(fYearStart.getFullYear(),fYearStart.getMonth(),1)
var dummy5=new Date(fYearStart.getFullYear(),fYearStart.getMonth(),1)
var q1End=new Date(dummy1.setMonth(dummy1.getMonth()+3))
var q1FinalEnd=new Date(dummy5.setMonth(dummy5.getMonth()+3))
q1FinalEnd.setSeconds(q1End.getSeconds()-1)
console.log(q1Start.toLocaleString())
console.log(q1FinalEnd.toLocaleString())
var q2Start=new Date(q1End.getFullYear(),q1End.getMonth(),1)
var dummy2=new Date(q1End.getFullYear(),q1End.getMonth(),1)
var dummy6=new Date(q1End.getFullYear(),q1End.getMonth(),1)
var q2End=new Date(dummy2.setMonth(dummy2.getMonth()+3))
var q2FinalEnd=new Date(dummy6.setMonth(dummy6.getMonth()+3))
q2FinalEnd.setSeconds(q2End.getSeconds()-1)
console.log(q2Start.toLocaleString())
console.log(q2FinalEnd.toLocaleString())
var q3Start=new Date(q2End.getFullYear(),q2End.getMonth(),1)
var dummy3=new Date(q2End.getFullYear(),q2End.getMonth(),1)
var dummy7=new Date(q2End.getFullYear(),q2End.getMonth(),1)
var q3End=new Date(dummy3.setMonth(dummy3.getMonth()+3))
var q3FinalEnd=new Date(dummy7.setMonth(dummy7.getMonth()+3))
q3FinalEnd.setSeconds(q3End.getSeconds()-1)
console.log(q3Start.toLocaleString())
console.log(q3FinalEnd.toLocaleString())
var q4Start=new Date(q3End.getFullYear(),q3End.getMonth(),1)
var dummy4=new Date(q3End.getFullYear(),q3End.getMonth(),1)
var dummy8=new Date(q3End.getFullYear(),q3End.getMonth(),1)
var q4End=new Date(dummy4.setMonth(dummy4.getMonth()+3))
var q4FinalEnd=new Date(dummy8.setMonth(dummy8.getMonth()+3))
q4FinalEnd.setSeconds(q4End.getSeconds()-1)
console.log(q4Start.toLocaleString())
console.log(q4FinalEnd.toLocaleString())