JavaScript的Date对象没有实现任何类型的add函数,这让我感到惊讶。

我只是想要一个函数,可以这样做:

var now = Date.now(); var fourHoursLater = now.addHours(4); 函数Date.prototype.addHours(h) { //我如何实现这个? }

我只是想要一些指路的指点。

我需要做字符串解析吗? 我可以使用setTime吗? 毫秒呢?

是这样的:

new Date(milliseconds + 4*3600*1000 /* 4 hours in ms */)?

这看起来真的很奇怪——它真的有用吗?


当前回答

我也认为原来的对象不应该被修改。因此,为了节省未来的人力,这里有一个基于Jason Harwig和Tahir Hasan回答的综合解决方案:

Date.prototype.addHours= function(h){
    var copiedDate = new Date();
    copiedDate.setTime(this.getTime() + (h*60*60*1000)); 
    return copiedDate;
}

其他回答

Date.prototype.addHours= function(h){
    this.setHours(this.getHours()+h);
    return this;
}

测试:

alert(new Date().addHours(4));

这是一种获取递增或递减数据值的简单方法。

const date = new Date()
const inc = 1000 * 60 * 60 // an hour
const dec = (1000 * 60 * 60) * -1 // an hour

const _date = new Date(date)
return new Date(_date.getTime() + inc)
return new Date(_date.getTime() + dec)

JavaScript本身有糟糕的日期/时间API。尽管如此,你可以在纯JavaScript中这样做:

Date.prototype.addHours = function(h) {
  this.setTime(this.getTime() + (h*60*60*1000));
  return this;
}

如果你想在一个更功能性的方式(不可变性),我会返回一个新的日期对象,而不是修改现有的,我不会改变原型,而是创建一个独立的函数。下面是例子:

/ / JS 函数addHoursToDate(日期,小时){ 返回new Date(new Date(Date).setHours(Date . gethours () + hours)); } / / TS 函数addHoursToDate(日期:日期,小时:数字):日期{ 返回new Date(new Date(Date).setHours(Date . gethours () + hours)); } let myDate = new Date(); console.log(替换) 2) console.log (addHoursToDate(替换)

检查它是否还没有定义。否则,在Date原型中定义它:

if (!Date.prototype.addHours) {
    Date.prototype.addHours = function(h) {
        this.setHours(this.getHours() + h);
        return this;
    };
}