52

我使用了以下功能:

function datediff()
{
  var dat1 = document.getElementById('date1').value;
  alert(dat1);//i get 2010-04-01
  var dat2 = document.getElementById('date2').value;
  alert(dat2);// i get 2010-04-13
 
  var oneDay = 24*60*60*1000;   // hours*minutes*seconds*milliseconds
  var diffDays = Math.abs((dat1.getTime() - dat2.getTime())/(oneDay));
  alert(diffDays);
}

我得到错误:

dat1.getTime()` is not a function
4

5 回答 5

62

那是因为你的dat1dat2变量只是字符串。

您应该解析它们以获取Date对象,对于该格式,我总是使用以下函数:

// parse a date in yyyy-mm-dd format
function parseDate(input) {
  var parts = input.match(/(\d+)/g);
  // new Date(year, month [, date [, hours[, minutes[, seconds[, ms]]]]])
  return new Date(parts[0], parts[1]-1, parts[2]); // months are 0-based
}

我使用这个函数是因为Date.parse(string)(or new Date(string)) 方法是依赖于实现的,并且yyyy-MM-dd格式可以在现代浏览器上工作,但不能在 IE 上工作,所以我更喜欢手动操作。

于 2010-04-13T07:15:43.077 回答
41

对于所有来到这里并确实使用日期类型变量的人,这是我找到的解决方案。它也适用于 TypeScript。

我遇到了这个错误,因为我尝试使用以下方法比较两个日期

var res = dat1.getTime() > dat2.getTime(); // or any other comparison operator

但是我确定我使用了 Date 对象,因为我使用带有 typescript 的 angularjs,并且我从一个类型化的 API 调用中获取了数据。

我不确定为什么会引发错误,但我假设因为我的 Object 是由 JSON 反序列化创建的,所以可能该getTime()方法根本没有添加到原型中。

解决方案

在这种情况下,根据您的日期重新创建日期对象将解决问题。

var res = new Date(dat1).getTime() > new Date(dat2).getTime()

编辑:

我是对的。类型将被转换为相应的类型,但它们不会被实例化。因此会有一个字符串转换为日期,这显然会导致运行时异常。

诀窍是,如果您使用带有非原始数据(例如日期或函数)的接口,则需要在您的 http 请求之后执行映射。

class Details {
    description: string;
    date: Date;
    score: number;
    approved: boolean;

    constructor(data: any) {
      Object.assign(this, data);
    }
}

并执行映射:

public getDetails(id: number): Promise<Details> {
    return this.http
               .get<Details>(`${this.baseUrl}/api/details/${id}`)
               .map(response => new Details(response.json()))
               .toPromise();
}

对于数组使用:

public getDetails(): Promise<Details[]> {
    return this.http
               .get<Details>(`${this.baseUrl}/api/details`)
               .map(response => {
                   const array = JSON.parse(response.json()) as any[];
                   const details = array.map(data => new Details(data));
                   return details;
               })
               .toPromise();
}

有关此主题的学分和更多信息,请点击链接。

于 2018-10-22T14:15:31.573 回答
11

要使用此函数/方法,您需要Date类的实例。

此方法始终与Date对象结合使用。

请参阅下面的代码:

var d = new Date();
d.getTime();

链接:http ://www.w3schools.com/jsref/jsref_getTime.asp

于 2010-04-13T07:14:08.540 回答
5

dat1 和 dat2 是 JavaScript 中的字符串。String 原型上没有 getTime 函数。我相信你想要 Date.parse() 函数:http ://www.w3schools.com/jsref/jsref_parse.asp

你会像这样使用它:

var date = Date.parse(dat1);
于 2010-04-13T07:15:59.317 回答
0

这是一个时间格式问题,请按照以下方式更改。

Date.parse(dat1) 

代替

dat1.getTime()
于 2022-02-25T14:56:03.877 回答