カスタム バインディング ハンドラ「foreachprop」を作成しました
ko.bindingHandlers.foreachprop = {
transformObject: function (obj) {
var properties = [];
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
properties.push({ key: key, value: obj[key] });
}
}
return properties;
},
init: function(element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
var value = ko.utils.unwrapObservable(valueAccessor()),
properties = ko.bindingHandlers.foreachprop.transformObject(value);
ko.applyBindingsToNode(element, { foreach: properties });
return { controlsDescendantBindings: true };
}
};
オブジェクトを反復処理する場合
<div data-bind="foreachprop: sections"></div>
これは機能しますが、コンテナレス コントロールを使用すると、同じデータに対して機能しません
<!-- ko foreachprop: sections --> <!-- /ko -->
カスタム バインディング ハンドラーに連続性のない制御フローを使用する方法
Jsfiddle は新しいhttp://jsfiddle.net/E6xq2/5/を作成しました