The arrow function cannot be invoked with the new keyword, because arrow functions don’t have a constructor. If you try to instantiate with a new keyword it will throw an error.
data:image/s3,"s3://crabby-images/e0226/e02268cb70814b7254db1f0d590dc45282256d1e" alt=""
No own this (call, apply & bind won’t work as expected)
In a traditional function, its internal this
value is dynamic, it depends on how the function is invoked. For example:
data:image/s3,"s3://crabby-images/6701f/6701f59408b133294e98b93fffb4de90b0c8ae23" alt=""
Unlike regular functions, arrow functions don’t have their own this
binding. If we access this in the arrow function it will return the this of the closest non-arrow parent function.
data:image/s3,"s3://crabby-images/305e1/305e138d72df71db4dd7c40c73ad52da0eac8875" alt=""
The value of this in the arrow function is determined at the time of declaration and never changes. So call
, apply
, bind
cannot change the value of the arrow function this
.
Comments
Post a Comment