私はknockout.jsを初めて使用し、ユーザーを表す次のオブジェクトにバインドしようとしています。
{
"$id": "1",
"$values": [
{
"$id": "2",
"Locations": {
"$id": "3",
"$values": []
},
"Photos": {
"$id": "4",
"$values": []
},
"UserId": 1,
"Name": "Test User"
}
]
}
ユーザーは、0個以上の場所、および0個以上の写真を表示できます。
ビューモデル:
function UsersViewModel() {
var self = this;
self.users = ko.observableArray();
var baseUri = 'http://localhost:46241/api/users';
$.getJSON(baseUri, function (data) {
self.users = data;
});
}
$(document).ready(function () {
ko.applyBindings(new UsersViewModel());
})
HTMLには、次のバインディングが含まれています。
<ul id="update-users" data-bind="foreach: users">
<li>
<div><div class="item">User ID</div>
<input type="text" data-bind="value: $data.UserId" />
</div>
<div><div class="item">Name</div>
<input type="text" data-bind="value: $data.Name" />
</div>
</li>
</ul>
私はこれを間違ってやっているのですか?または、場所と写真へのユーザーのオブジェクト参照がバインディングを台無しにしている可能性がありますか?