从JavaScript中的日期中减去天


602

有谁知道约会(例如今天)和回溯X天的简单方法吗?

因此,例如,如果我想计算今天之前5天的日期。


4
使用公认的答案,我发现了问题。显然,在setDate()中使用负值无法正常工作。请参阅stackoverflow.com/a/9037132/792287,以获取另一种(更好的)解决方案。
vandiedakaf


Answers:


960

尝试这样的事情:

 var d = new Date();
 d.setDate(d.getDate()-5);

请注意,这将修改日期对象并返回更新日期的时间值。

var d = new Date();

document.write('Today is: ' + d.toLocaleString());

d.setDate(d.getDate() - 5);

document.write('<br>5 days ago was: ' + d.toLocaleString());


9
输出的结果是一长串整数。是否知道如何将其格式化为05/14/2012?
user525146

162
鉴于这是google的顶部,我想我会回答以上评论:new Date(new Date().setDate(new Date().getDate()-5))-将在5天前。在答案示​​例中,将其传递给新日期以获取日期对象。所以,new Date(d)是你想要的。
杰西2012年

8
问题在于,您可能会以00结束,该日期不是有效的日期值。
DominicM

24
setDate(-1)将设置日期为本月的最后一天
彼得

5
@ user525146询问如何格式化数字,而不是数字。无需居高临下的答案。要格式化的数量,日期用一个toString方法,如toISOStringtoDateString
错误的请求

83
var dateOffset = (24*60*60*1000) * 5; //5 days
var myDate = new Date();
myDate.setTime(myDate.getTime() - dateOffset);

如果您要在整个Web应用程序中执行很多头痛检查日期操作,DateJS将使您的生活更加轻松:

http://simonwillison.net/2007/Dec/3/datejs/


23
这是一个极端的情况,但这可能会在夏令时的开始/结束时失败。您不会减去5天,而是5 * 24小时。夏令时的第一天只有23小时长,最后一天是25小时长。通常并不重要,但这是需要考虑的事情。
基普(Kip)

11
@Kip我讨厌夏令时...和时区。我们都应该转向格林尼治标准时间。
cwallenpoole

6
@cwallenpoole不会破坏您的泡沫,但即使在格林威治,他们也使用DST。因此,如果您真的想参加格林尼治标准时间(GMT),则仅限于冰岛和一些西非国家/地区。
基普2015年

1
用这种方法的问题是,它不会用新一年的工作等等
丹尼尔·威廉姆斯

4
@danielWilliams新的一年怎么办?getTime()并且setTime()是从纪元以来的毫秒数。时间是否跨过年份边界并不重要。
Mashmagar '19

51

它是这样的:

var d = new Date(); // today!
var x = 5; // go back 5 days!
d.setDate(d.getDate() - x);

输出的结果是一长串整数。是否知道如何将其格式化为05/14/2012?
user525146

7
d.setDate的返回值确实是一个整数值。但是,由于“ d”的实际值已被修改,此时您可能实际上对返回值不感兴趣。现在您真正的问题是如何格式化日期,日期现在是“ d”,而不是setDate的返回值。(好吧,它实际上是返回值,但是到那时它还不是一个日期,并且我不想让您感到困惑-只需使用d,它将更快。)要格式化日期,您需要d.getMonth(),d.getFullYear()和d.getDate()方法。您要在d.getMonth()中添加一个,因为Jan是0。–
Chris Nielsen

2
作为一种简单的方法:function getDaysAgo(b){var a=new Date;a.setDate(a.getDate()-b);return a};然后var daysAgo45 = getDaysAgo(45);
SpYk3HH 2015年

@MiroKrsjak当然,如果您越过月底/开始,这将起作用。为什么不起作用?
克里斯·尼尔森

23

我注意到getDays + X在日期/月份范围内不起作用。只要您的日期不早于1970,就可以使用getTime。

var todayDate = new Date(), weekDate = new Date();
weekDate.setTime(todayDate.getTime()-(7*24*3600000));

3
我注意到了。我更惊讶的是没有,或者我想念什么吗?
肖恩·格洛弗

11
这是不正确的,新的Date()。setDate(-1)将为您提供上个月的最后一天。
zbrunson 2014年

2
在夏时制开始/结束的边缘情况下,这也是不正确的。假设每天有24小时,那么您的方法将减去7 * 24小时。DST的第一天只有23小时,而最后一天是25小时。setDate(getDate()-7)没有此问题。
2015年

1
getTime适用于通用时间。因此,可以从Date对象中正确减去7天的时间。当您将其转换为指定时区的字符串时,它将正确显示该时区的时间。
2015年

更改时间当天要小心。当我们跌倒时,那一天有25个小时,因此从午夜减去24个小时将使您在同一天着陆。但是,如果您在每次操作后的第二天四舍五入到最近的午夜,则此技术(减去毫秒)将起作用。您可以先添加12小时,然后将小时设置为零,以实现此目的。
Magmatic

18

获取moment.js。所有很酷的孩子都在使用它。它具有更多的格式化选项,等等。

var n = 5;
var dateMnsFive = moment(<your date>).subtract(n , 'day');

可选的!转换为JS Date obj以进行角度绑定。

var date = new Date(dateMnsFive.toISOString());

可选的!格式

var date = dateMnsFive.format("YYYY-MM-DD");

将您的日期传递到时刻,您将开始收到警告。弃用警告:提供的值不是公认的RFC2822或ISO格式。此刻的构建工作归结于js Date(),它在所有浏览器和版本之间都不可靠。不建议使用非RFC2822 / ISO日期格式,并将在即将发布的主要版本中将其删除。有关更多信息,请参考momentjs.com/guides/#/warnings/js-date
切换

13

我为Date创建了此原型,以便可以传递负值减去天数,传递正值添加天数。

if(!Date.prototype.adjustDate){
    Date.prototype.adjustDate = function(days){
        var date;

        days = days || 0;

        if(days === 0){
            date = new Date( this.getTime() );
        } else if(days > 0) {
            date = new Date( this.getTime() );

            date.setDate(date.getDate() + days);
        } else {
            date = new Date(
                this.getFullYear(),
                this.getMonth(),
                this.getDate() - Math.abs(days),
                this.getHours(),
                this.getMinutes(),
                this.getSeconds(),
                this.getMilliseconds()
            );
        }

        this.setTime(date.getTime());

        return this;
    };
}

因此,要使用它,我可以简单地写:

var date_subtract = new Date().adjustDate(-4),
    date_add = new Date().adjustDate(4);

2
您可以将d.setDate(d.getDate() + days)正数和负数都用于天数,以分别增加和减少天数。并且它应该在实例上工作(就像其他Date方法一样),而不是创建并返回副本。
RobG

13

一些现有的解决方案已经接近,但与我想要的不完全相同。此函数可使用正值或负值,并处理边界情况。

function addDays(date, days) {
    return new Date(
        date.getFullYear(),
        date.getMonth(),
        date.getDate() + days,
        date.getHours(),
        date.getMinutes(),
        date.getSeconds(),
        date.getMilliseconds()
    );
}

2
如果我使用此方法在当月的15号加上20天,它会“溢出”到下个月吗?似乎没有。
宝来

2
@Bora-​​是的,如果需要,它可以正确地增加月份。例如,将20天添加到8月15日:addDays(new Date(2015,07,15),20)将返回“ 2015年9月4日星期五00:00:00 GMT-0700(PDT)”
乔尔·菲尔莫尔

12

我喜欢以毫秒为单位进行数学运算。所以用Date.now()

var newDate = Date.now() + -5*24*3600*1000; // date 5 days ago in milliseconds

如果你喜欢它格式化

new Date(newDate).toString(); // or .toUTCString or .toISOString ...

注意:Date.now()在较旧的浏览器(例如我认为的IE8)中不起作用。Polyfill在这里

2015年6月更新

@socketpair指出了我的草率。正如他/她所说:“由于时区规则,一年中的某天有23个小时,有25个小时。”

为了进一步说明这一点,如果您要计算夏令时更改的时区中的5天前的本地日,并且您选择了夏令时,则上面的答案会出现夏令时错误

  • 假设(错误地)Date.now()为您提供了当前的本地时间,或者
  • 用途.toString(),它返回本地日期,因此与Date.now()UTC中的基准日期不兼容。

但是,如果您全部使用UTC进行数学运算,则可以使用它,例如

答:您想从现在(UTC)的UTC日期起5天前

var newDate = Date.now() + -5*24*3600*1000; // date 5 days ago in milliseconds UTC
new Date(newDate).toUTCString(); // or .toISOString(), BUT NOT toString

B.您使用UTC基准日期(不是“现在”)开始,使用 Date.UTC()

newDate = new Date(Date.UTC(2015, 3, 1)).getTime() + -5*24*3600000;
new Date(newDate).toUTCString(); // or .toISOString BUT NOT toString

3
这不准确。根据时区规则,一年中的某天有23小时,而有些则有25小时。
套对2015年

当出现leap秒时,我会担心故障情况……所以对于关键代码可能不好。
robocat 2015年

12

我发现getDate()/ setDate()方法存在一个问题,即它太容易将所有内容转换为毫秒,并且有时语法难以理解。

相反,我想解决一个事实,即1天= 86,400,000毫秒。

因此,对于您的特定问题:

today = new Date()
days = 86400000 //number of milliseconds in a day
fiveDaysAgo = new Date(today - (5*days))

奇迹般有效。

我一直使用这种方法进行30/60/365天的滚动计算。

您可以轻松地对此进行推断,以创建几个月,几年等的时间单位。


11

将您的日期分割成几部分,然后返回带有调整后值的新日期

function DateAdd(date, type, amount){
    var y = date.getFullYear(),
        m = date.getMonth(),
        d = date.getDate();
    if(type === 'y'){
        y += amount;
    };
    if(type === 'm'){
        m += amount;
    };
    if(type === 'd'){
        d += amount;
    };
    return new Date(y, m, d);
}

请记住,月是从零开始的,但天不是。例如,新日期(2009,1,1)== 2009年2月1日,新日期(2009,1,0)== 2009年1月31日;


2
如果您以这种方式向日期添加例如50天会怎样?它将日期定为2009年8月68日吗?还是确定这总是正确地包装到适当的月份和/或年份?
杰斯珀,

用于将addDays,addMonths和addYears添加到Date.prototype。漂亮又简单。
Scott Isaacs

1
这应该是正确的答案-即使在接受的答案失败的一年的最后一天也可以使用。
克里斯,2015年

不适用于年份从1到99的日期。;-)最好只使用get *set *方法。
RobG

8

无需使用第二个变量,您可以将x替换为x天:

let d=new Date(new Date().getTime() - (7 * 24 * 60 * 60 * 1000))

5

function addDays (date, daysToAdd) {
  var _24HoursInMilliseconds = 86400000;
  return new Date(date.getTime() + daysToAdd * _24HoursInMilliseconds);
};

var now = new Date();

var yesterday = addDays(now, - 1);

var tomorrow = addDays(now, 1);


2

我创建了一个用于日期操作的函数。您可以添加或减去任何天数,小时数,分钟数。

function dateManipulation(date, days, hrs, mins, operator) {
   date = new Date(date);
   if (operator == "-") {
      var durationInMs = (((24 * days) * 60) + (hrs * 60) + mins) * 60000;
      var newDate = new Date(date.getTime() - durationInMs);
   } else {
      var durationInMs = (((24 * days) * 60) + (hrs * 60) + mins) * 60000;
      var newDate = new Date(date.getTime() + durationInMs);
   }
   return newDate;
 }

现在,通过传递参数来调用此函数。例如,这是一个函数调用,用于获取从今天起3天之前的日期。

var today = new Date();
var newDate = dateManipulation(today, 3, 0, 0, "-");

2

使用MomentJS

function getXDaysBeforeDate(referenceDate, x) {
  return moment(referenceDate).subtract(x , 'day').format('MMMM Do YYYY, h:mm:ss a');
}

var yourDate = new Date(); // let's say today
var valueOfX = 7; // let's say 7 days before

console.log(getXDaysBeforeDate(yourDate, valueOfX));
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script>


1

最佳答案导致我的代码出现错误,该错误将在本月的第一天设置当前月份的将来日期。这是我所做的

curDate = new Date(); // Took current date as an example
prvDate = new Date(0); // Date set to epoch 0
prvDate.setUTCMilliseconds((curDate - (5 * 24 * 60 * 60 * 1000))); //Set epoch time


0

我喜欢以下内容,因为它是一行。DST更改并不完美,但通常足以满足我的需求。

var fiveDaysAgo = new Date(new Date() - (1000*60*60*24*5));

0

对我来说,所有组合都可以在下面的代码片段中正常工作,该片段适用于Angular-2实现,如果您需要添加天数,则传递正数numberDays,如果需要减去负数,传递负数numberofDays

function addSubstractDays(date: Date, numberofDays: number): Date {
let d = new Date(date);
return new Date(
    d.getFullYear(),
    d.getMonth(),
    (d.getDate() + numberofDays)
);
}

0

我从date.js中获得了不错的成绩:

http://www.datejs.com/

d = new Date();
d.add(-10).days();  // subtract 10 days

真好!

网站包含此美女:

Datejs不仅解析字符串,还将它们整洁地切成两部分


0

如果要减去天数并以易于DateHelper理解的格式设置日期格式,则应考虑创建一个看起来像这样的自定义对象:

var DateHelper = {
    addDays : function(aDate, numberOfDays) {
        aDate.setDate(aDate.getDate() + numberOfDays); // Add numberOfDays
        return aDate;                                  // Return the date
    },
    format : function format(date) {
        return [
           ("0" + date.getDate()).slice(-2),           // Get day and pad it with zeroes
           ("0" + (date.getMonth()+1)).slice(-2),      // Get month and pad it with zeroes
           date.getFullYear()                          // Get full year
        ].join('/');                                   // Glue the pieces together
    }
}

// With this helper, you can now just use one line of readable code to :
// ---------------------------------------------------------------------
// 1. Get the current date
// 2. Subtract 5 days
// 3. Format it
// 4. Output it
// ---------------------------------------------------------------------
document.body.innerHTML = DateHelper.format(DateHelper.addDays(new Date(), -5));

(另请参阅此小提琴


0

请参见以下代码,从当前日期中减去天数。另外,根据扣除的日期设置月份。

var today = new Date();
var substract_no_of_days = 25;

today.setTime(today.getTime() - substract_no_of_days* 24 * 60 * 60 * 1000);
var substracted_date = (today.getMonth()+1) + "/" +today.getDate() + "/" + today.getFullYear();

alert(substracted_date);

-1

设置日期时,日期会转换为毫秒,因此您需要将其转换回日期:

该方法还考虑了新年变更等。

function addDays( date, days ) {
    var dateInMs = date.setDate(date.getDate() - days);
    return new Date(dateInMs);
}

var date_from = new Date();
var date_to = addDays( new Date(), parseInt(days) );

-1

您可以使用Javascript。

var CurrDate = new Date(); // Current Date
var numberOfDays = 5;
var days = CurrDate.setDate(CurrDate.getDate() + numberOfDays);
alert(days); // It will print 5 days before today

对于PHP,

$date =  date('Y-m-d', strtotime("-5 days")); // it shows 5 days before today.
echo $date;

希望对您有帮助。


-1

我转换为毫秒并扣除了天,否则月份和年份将不会更改且合乎逻辑

var numberOfDays = 10;//number of days need to deducted or added
var date = "01-01-2018"// date need to change
var dt = new Date(parseInt(date.substring(6), 10),        // Year
              parseInt(date.substring(3,5), 10) - 1, // Month (0-11)
              parseInt(date.substring(0,2), 10));
var new_dt = dt.setMilliseconds(dt.getMilliseconds() - numberOfDays*24*60*60*1000);
new_dt = new Date(new_dt);
var changed_date = new_dt.getDate()+"-"+(new_dt.getMonth()+1)+"-"+new_dt.getFullYear();

希望有所帮助


-1

var date = new Date();
var day = date.getDate();
var mnth = date.getMonth() + 1;

var fDate = day + '/' + mnth + '/' + date.getFullYear();
document.write('Today is: ' + fDate);
var subDate = date.setDate(date.getDate() - 1);
var todate = new Date(subDate);
var today = todate.getDate();
var tomnth = todate.getMonth() + 1;
var endDate = today + '/' + tomnth + '/' + todate.getFullYear();
document.write('<br>1 days ago was: ' + endDate );


1
您应该始终对您的代码/答案发表评论,因为某些人可能无法理解您所做的事情
Michael

-1

使用现代JavaScript函数语法

const getDaysPastDate = (daysBefore, date = new Date) => new Date(date - (1000 * 60 * 60 * 24 * daysBefore));

console.log(getDaysPastDate(1)); // yesterday


-1

试试这个

dateLimit = (curDate, limit) => {
    offset  = curDate.getDate() + limit
    return new Date( curDate.setDate( offset) )
}

currDate可以是任何日期

限制可以是天数之差(对未来为正,对过去为负)


-1

这将为您提供最后10天的结果110%正常工作,您将不会遇到任何类型的问题

var date = new Date();
var day=date.getDate();
var month=date.getMonth() + 1;
var year=date.getFullYear();
var startDate=day+"/"+month+"/"+year;
var dayBeforeNineDays=moment().subtract(10, 'days').format('DD/MM/YYYY');
startDate=dayBeforeNineDays;
var endDate=day+"/"+month+"/"+year;

您可以根据需要更改减日期



-2

var d = new Date();

document.write('Today is: ' + d.toLocaleString());

d.setDate(d.getDate() - 31);

document.write('<br>5 days ago was: ' + d.toLocaleString());

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.