コード:
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 メソッドにあります。デフォルトでは、コンテキストをバインドしない場合、これは == UserToDelete - ビューモデル オブジェクトではありません。constructor: に追加するとthis.removeUser = this.removeUser.bind(this); (manually enforce context)
、コンテキストは必要に応じて this == ビューモデルになりますが、TypeScript は「関数を (user:User) に変換できません =>void には呼び出し署名が必要ですが、関数には署名がありません」と文句を言います。