ノックアウト マッピング プラグインを介して生成された次の ViewModel を検討してください。
var originalData = {
"QuoteSelectedViewModel": {
"ProductName": "Select",
"CoverQuotesViewModel": [
{
"Code": 1,
"Label": "Première Assistance 24h/24 (GRATUITE)",
"IsMandatory": true,
"IsSelected": true,
"DependsOn": []
},
{
"Code": 2,
"Label": "Assistance PLUS 24h/24",
"IsMandatory": false,
"IsSelected": false,
"DependsOn": []
},
{
"Code": 8,
"Label": "Heurts Animaux / Force de la Nature",
"IsMandatory": false,
"IsSelected": false,
"DependsOn": [
2
]
},
]}
}
var viewModel = ko.mapping.fromJS(originalData);
ko.applyBindings(viewModel);
<div data-bind="with: QuoteSelectedViewModel">
selected quote is : <span data-bind="text: ProductName"></span>
<!-- ko foreach: CoverQuotesViewModel -->
<br/>
<div data-bind: if: IsVisible>
<input type="checkbox" data-bind="checked: IsSelected"></input>
<input type="text" data-bind="value: Label, enable: IsSelected"></input>
</div>
<!-- /ko -->
</div>
ここで、IsVisible が false を返すときに div を非表示にしたいと思います。IsVisible はまだ存在しません。これは、CoverQuotesViewModel 配列の各要素に対して計算された監視可能な関数である必要があります。
各要素でこの計算された観測可能な関数を生成するにはどうすればよいですか?
ありがとう
[編集] ここに jsfiddle を追加しました: http://jsfiddle.net/graphicsxp/fpKWM/
[EDIT2]実際にノックアウトドキュメントはそれを行う方法について明確です:
もちろん、create コールバック内で、必要に応じて ko.mapping.fromJS への別の呼び出しを行うことができます。典型的なユースケースは、元の JavaScript オブジェクトを追加の計算されたオブザーバブルで拡張したい場合です。
var myChildModel = function(data) { ko.mapping.fromJS(data, {}, this);
this.nameLength = ko.computed(function() { return this.name().length; }, this); }
[編集]
Paul の提案に従った完全なコードは次のとおりです (getQuotesSuccess は AJAX 成功ハンドラです)。
viewModel.getQuotesSuccess = function (result) {
var myCoverQuotesViewModel = function (data, parent) {
var self = this;
ko.mapping.fromJS(data, {}, this);
self.IsVisible = ko.computed(function () {
var visible = true;
if (self.DependsOn().length > 0) {
$.each(self.DependsOn(), function (index, value) {
var dependency = viewModel.QuoteSelectedViewModel().CoverQuotesViewModel.filterByProperty("Code", value);
if (dependency().length > 0) {
visible = visible & dependency()[0].IsSelected();
} else {
visible = false;
}
});
}
return visible;
}, this);
}
var mapping = {
'CoverQuotesViewModel': {
create: function (options) {
return new myCoverQuotesViewModel(options.data, options.parent);
}
}
}
ko.mapping.fromJS(result, mapping, viewModel);
};