Scope of this is lost when passing a member function to setInterval
See original GitHub issueTypeScript Version: 1.8.10
When passing a member function to setInterval, the scope of ‘this’ is lost within the callback, though the structure of the code (given experience of any object orientated language) indicates it shouldn’t be.
Example code
export class SetIntervalTest {
private someNumber: number = 1;
trigger() {
setInterval(this.setIntervalCallback, 400);
}
private setIntervalCallback() {
console.log(this.someNumber);
}
}
Expected behavior When console.log(this.someNumber); is called, the scope of this is within the scope of the SetIntervalTest interval instance, printing ‘1’.
Actual behavior: The scope of this is pulled from global scope, resulting in this.someNumber being ‘undefined’. If that isn’t possible, the compiler should indicate the expected behaviour is not what you’re going to get.
To fix this i need to change ‘setInterval(this.setIntervalCallback, 400);’ to ‘setInterval(() => this.setIntervalCallback(), 400);’ so ‘this’ is correctly scoped in the callback.
Issue Analytics
- State:
- Created 7 years ago
- Reactions:3
- Comments:8 (6 by maintainers)
Top GitHub Comments
See “something about
this
” in https://github.com/Microsoft/TypeScript/wiki/FAQ#common-feature-requestsYou can have the “correct” code generated by using an arrow function:
@leewinder ,
should be just working fine so that the callback can see
this
.