在我问我的问题之前,这是我的Typescript类:
export class Info {
private currentId: number;
private addToListButton: HTMLInputElement;
constructor() {
this.currentId = +(<HTMLInputElement> document.getElementById("Example")).value;
this.addToListButton = <HTMLInputElement> document.getElementById("addToList");
this.registerEvents();
}
private registerEvents(): void {
this.addToListButton.addEventListener("click", (() => this.addToList()));
}
private addToList(): void {
var data: SomeModel;
data.id = this.currentId;
// ajax stuff
}
}
我的问题是,当我想获取模型的“ currentId”时,它始终是未定义的。 我可以在同一函数中使用另一个变量“ addToListButton”,而不会出现问题。
我看不到那里是什么问题。
感谢您的帮助!
答案 0 :(得分:2)
在此处调用函数this
时,函数addToList
中的关键字Info
不引用类this.addToListButton.addEventListener("click", (() => this.addToList()));
的实例。
要让this
引用实例,请使用箭头功能:
private const addToList = (): void => { // Arrow function
var data: SomeModel;
data.id = this.currentId;
// ajax stuff
}
Here是关于什么箭头功能的一些解释。
答案 1 :(得分:0)
在addToList()
方法中,关键字this
是指事件上下文,而不是Info
对象上下文。
要以这种方式使用,您需要将方法绑定到类。将此添加到构造函数中:
this.addToList = this.addToList.bind(this);