ノックアウトで複雑なバインディングを実行しようとしています(少なくとも私のような初心者にとっては)。
次のデータを検討してください。
var originalData = {
id: 1,
name: "Main",
children: [ { id: 2, name: "bob", children: []}, { id: 3, name: "ted", children: [{id: 5, name:"albert"}, {id: 9, name: "fred"}]} ],
selectedChild: { id: 2, name: "bob" }
};
<table>
<tr>
<td data-bind="text: name"></td>
</tr>
<tr data-bind="if: children().length > 0">
<td>
<select data-bind="options: children,
optionsText: function(item){
return item.name;
},
optionsCaption: 'Choose...'"></select>
</td>
</tr>
わかりました、それは簡単な部分でした。
難しいのは、リストでアイテムが選択されるたびに、このアイテムに子がある場合、新しい選択ボックスが下に表示されることです。そのデータソースは、最初の選択ボックスで選択された項目の子になります。もちろん、それはどのレベルの深さでも続く可能性があります。
ノックアウトでこの問題を解決するにはどうすればよいですか?
これまでの jsfiddle のサンプルをまとめました: http://jsfiddle.net/graphicsxp/qXZjM/