Collectives™ on Stack Overflow
Find centralized, trusted content and collaborate around the technologies you use most.
Learn more about Collectives
Teams
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
Learn more about Teams
setTimeout(function(){
console.log(`${ this.nombre} smash!`); //HERE is the error but IDK why
},1000);
setTimeout(()=>{
console.log(`${ this.nombre} smash!`);
},1000);
hulk.smash();
I am learning to use arrow functions and the difference between using arrow functions and using functions, but I get the error when I put the word "this" in the function, because when I use "this" in the arrow function everything is okay.
I tried adding
"noImplicitAny": false,
tsconfig.json
but that didn't work.
this
inside setTimeout
refers to the function context, not to the hulk object. Arrow functions don't create their own context (their own this) since they inherit it.
Arrow function expressions
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.