So I'm trying to add a class to an element using Knockout.js based on whether a child checkbox is checked or not. To do so, I'm trying to pass this
as an argument to my function. Currently, my abridged DOM structure is the following:
<tr data-bind="css: { selected: isRowChecked(this) }">
<td><label><input type="checkbox"></label></td>
</tr>
An my isRowChecked
function is this (I'm using jQuery to locate the input):
function isRowChecked(elem) {
var checkbox = $(elem).find('input[type="checkbox"]');
return checkbox.checked;
}
Yet, if I console.log
elem
all I get is the global window object.
It is not feasible to use jQuery to solve this problem completely as the project I am working in is already using knockout nearly exclusively. Any ideas?
You should be able to accomplish this by passing the special binding context variable $element. It's the last variable discussed here.
<div id="item1" data-bind="text: $element.id"></div>
In your case, that would look like this: