首页 > 其他分享 >[Typescript] @typescript-eslint/unbound-method

[Typescript] @typescript-eslint/unbound-method

时间:2022-12-15 20:59:15浏览次数:44  
标签:function ... typescript unbound Typescript sendMessage method

It is useful to enable 

'@typescript-eslint/unbound-method': 'error',

because this kind of error is related to this keyword, sometime it is hard to notice during code review.

Avoid referencing unbound methods which may cause unintentional scoping of `this`.

If your function does not access `this`, you can annotate it with `this: void`, or consider using an arrow function instead.

class Endpoint {
 sendMessage() {
   ...
   this.sendEncodeMessage()
 }
    
 private sendEncodedMessage() {
  ...
 }
}
    
// Consumer
const {sendMessage} = endpoint; // instance of endpoint

// if you call sendMessage(), this keyword inside of function is undefined

 

Fix:

class Endpoint {
 sendMessage = () => {
   ...
   this.sendEncodeMessage()
 }
    
 private sendEncodedMessage = () => {
  ...
 }
}
    
// Consumer
const {sendMessage} = endpoint; // instance of endpoint

sendMessage() // works!

 

So be careful when using destructing syntax of a function call!

To avoid this kind of mistake, you can enable '@typescript-eslint/unbound-method': 'error',

标签:function,...,typescript,unbound,Typescript,sendMessage,method
From: https://www.cnblogs.com/Answer1215/p/16985988.html

相关文章