:imprenta contexto equivocado este Código
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>
El problema es que en el método removeuser. De forma predeterminada, si no enlace el contexto, esto == UserToDelete - no viewOl objeto objeto. Si agrego al constructor: this.removeUser = this.removeUser.bind(this); (manually enforce context)
, entonces el contexto es necesario como este == viewmodel, pero luego TypeScript se queja por "No se puede convertir la función a (usuario: Usuario) => void requiere una firma de llamada, pero la función carece de una."
Si no te importa HTML desordenado esta es una alternativa: Remove –