Kod:Typescript niewłaściwy kontekst tego
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>
Problem jest w metodzie RemoveUser. Domyślnie, jeśli nie wiążę kontekstu, to == UserToDelete - nie viewModel obiektu. Jeśli dodaję do konstruktora: this.removeUser = this.removeUser.bind(this); (manually enforce context)
, kontekst jest w razie potrzeby to == viewmodel, ale następnie TypeScript narzeka na "Nie można przekonwertować funkcji na (użytkownik: użytkownik) => void wymaga sygnatur połączeń, ale funkcja nie ma jednego."
Jeśli nie masz nic przeciwko niechlujnemu HTML, jest to alternatywa: Remove –