Borislav Hadzhiev
Reading timeยท2 min
Photo from Unsplash
The "TypeError: date.getHours is not a function" error occurs when the
getHours()
method is called on a value that is not a date object.
To solve the error, convert the value to a date before calling the method or
make sure to only call the getHours()
method on valid date objects.
Here is an example of how the error occurs.
const date = Date.now(); console.log(date); // ๐๏ธ 1639... // โ๏ธ TypeError: date.getHours is not a function const result = date.getHours();
We called the Date.now()
function, which returns an integer, and tried to call
the
Date.getHours()
method on it, which caused the error.
getHours()
method on valid Date
objectsTo solve the error, make sure to only call the getHours()
method on valid date
objects.
const t1 = new Date().getHours(); console.log(t1); // ๐๏ธ 18 const t2 = new Date('Sept 24, 22 13:20:18').getHours(); console.log(t2); // ๐๏ธ 13
You can get a date object by passing a valid date to the Date() constructor.
getHours()
on an invalid Date
returns NaN
Note that if an invalid date is passed to the Date()
constructor, you would
get NaN
(not a number) value back.
const d1 = new Date('invalid').getHours(); console.log(d1); // ๐๏ธ NaN
You can console.log
the value you are calling the getHours
method on and see
if it's a valid Date
object.
Date
before calling getHours
You could conditionally check if the value is a Date
object in the following
way.
const d1 = new Date(); if (typeof d1 === 'object' && d1 !== null && 'getHours' in d1) { const result = d1.getHours(); console.log(result); // ๐๏ธ 18 }
Our if
condition uses the logical AND (&&) operator, so for the if
block to
run, all of the conditions have to be met.
d1
variable stores a value with a type of object because dates have a type of object
.Then we check if the variable is not equal to null
.
Unfortunately, if you check the type of null - console.log(typeof null)
, you
will get an "object"
value back, so we have to make sure the value is not
null
.
console.log(typeof null); // ๐๏ธ object
getHours
property.Then we know we can safely call the getHours
method on the object.