我在网页上有一个烦人的bug:

date.GetMonth()不是函数

所以,我想我做错了什么。变量date不是date类型的对象。如何在Javascript中检查数据类型?我试图添加一个if(日期),但不起作用。

function getFormatedDate(date) {
    if (date) {
       var month = date.GetMonth();
    }
}

所以,如果我想编写防御性代码并防止日期(不是一个)被格式化,我该怎么做?

谢谢

UPDATE:我不想检查日期的格式,但我想确保传递给getFormatedDate()方法的参数是date类型。


当前回答

您可以使用以下代码:

(myvar instanceof Date) // returns true or false

其他回答

你就不能用

function getFormatedDate(date) {
    if (date.isValid()) {
       var month = date.GetMonth();
    }
}

使用try/catch的方法

函数getFormattedDate(date=new date()){尝试{date.toISOString();}捕获(e){date=新日期();}返回日期;}console.log(getFormattedDate());console.log(getFormattedDate('AAAA'));console.log(getFormattedDate(新日期('AAAA')));console.log(getFormattedDate(新日期(2018,2,10));

箭头函数

const isValidDate = (value: any) => value instanceof Date && !isNaN(value);

功能:

function isValidDate(d) {
  return d instanceof Date && !isNaN(d);
}

我在React钩子上遇到了一些问题,其中Date将在稍后出现/延迟加载,然后初始状态不能为null,它不会通过ts检查,但显然空Object会成功!:)

const [birthDate, setBirthDate] = React.useState({})

<input
  value={birthDate instanceof Date ? birthDate.toISOString() : ''}
  name="birthDay"
/>

受这个答案的启发,这个解决方案在我的情况下有效(我需要检查从API收到的值是否为日期):

!isNaN(Date.parse(new Date(YourVariable)))

通过这种方式,如果它是来自客户端或任何其他对象的随机字符串,您可以发现它是否是类似日期的对象。