ノックアウトに問題があります。ボックスをチェックすると、すべてチェックされます...
これは私が持っているものです:_Categories_Listにはすべてのアイテムがあり、My_categoriesは各IDを追加したい空のリストです
これはコードです:
<!-- ko foreach: _Categories_List -->
<input type="checkbox" data-bind="attr: {value: $data}, checked: $root.My_categories" />
<span data-bind="text: CODE"></span><br />
<!-- /ko -->
そして、これはコードの JS 部分です (私は他の誰かの作業を構築していて、mapping.fromJS を参照して同じコードを使用する必要があるため、コードがドキュメントにどのように記載されているかについてこれを実際に変更することはできません):
var Poi = new Object();
Poi.My_categories = [];
var _Poi = ko.mapping.fromJS(Poi);
var Categories_List = [];
var _Categories_List = ko.mapping.fromJS(Categories_List);
$(document).ready
(
function () {
ko.applyBindings(_Poi);
// here there's an ajax function to load the categories returned in i_Input.My_Result, then:
ko.mapping.fromJS(i_Input.My_Result, _Categories_List);
}
);
ajax からロードされたオブジェクトは次のようになります。
{"My_Result":[
{"CODE":"chalet","DEF_POIS_CATEGORY_ID":2,"DESCRIPTION":"chalet","ENTRY_DATE":"2012-10-10","ENTRY_USER_ID":2,"OWNER_ID":1},
{"CODE":"vila","DEF_POIS_CATEGORY_ID":3,"DESCRIPTION":"villa","ENTRY_DATE":"2012-10-10","ENTRY_USER_ID":2,"OWNER_ID":1}
]}