コード:活字体間違ったコンテキストこの
export class ViewModel {
public users: knockout.koObservableArrayBase;
constructor() {
this.users = ko.observableArray([]);
this.removeUser = this.removeUser.bind(this);//<-- Here compiller shows error
}
removeUser(user: User): void {
this.users.remove(user);
}
}
HTML:
<table>
<thead>
<tr>
<th>Name</th>
<th>Surname</th>
</tr>
</thead>
<tbody data-bind="foreach: users">
<tr>
<td><a href="#" data-bind="click: $root.removeUser">Remove</a></td>
<td data-bind="text: name"></td>
<td data-bind="text: surname"></td>
</tr>
</tbody>
</table>
問題ははremoveUser方法です。デフォルトでは、コンテキストをバインドしないと、this == UserToDelete - viewModelオブジェクトではありません。コンストラクタに追加した場合:this.removeUser = this.removeUser.bind(this); (manually enforce context)
、context == viewmodelですが、「関数を(user:User)=> voidにするとコールシグネチャは必要ですが、Functionには関数がありません」という文言があります。
あなたが混乱したHTMLを気にしない場合、これは別の方法です:Remove –