data:image/s3,"s3://crabby-images/7f46d/7f46d11fb21b05eab569e88581bc46a8c18c8eaa" alt="What is the Output of this Code?"
What is the Output of this Code?
Given the following method calls in JavaScript, what is the output?
Copied to clipboard! Playground
const circle = {
radius: 10,
diameter() {
return this.radius * 2;
},
perimeter: () => 2 * Math.PI * this.radius
};
circle.diameter();
circle.perimeter();
The correct answer is NaN
. circle.diameter
executes without the problem but perimeter
is defined as an arrow function. Arrow functions donβt bind their own context which means this.radius
will be undefined
. And 2 * Math.PI * undefined
will be equal to NaN
.
data:image/s3,"s3://crabby-images/f820a/f820a058374a486e5b654a98080f45758fb18caa" alt="What happens if you call this in an arrow function?"
data:image/s3,"s3://crabby-images/ff2b3/ff2b3d83bf9eb8c9577763e157461f30534536b9" alt="What Is βthisβ, After All? β A Look at JavaScript this Keyword"
Resources:
π More Webtips
data:image/s3,"s3://crabby-images/1eab3/1eab320c0a738a9c2b358948c8bf6b6606d12b07" alt="Mentoring"
Rocket Launch Your Career
Speed up your learning progress with our mentorship program. Join as a mentee to unlock the full potential of Webtips and get a personalized learning experience by experts to master the following frontend technologies: