オブザーバブルのオブザーバブルオブジェクトを作りたいです。例えば:
var Project = function(id, name, custId) {
this.id = ko.observable(id);
this.name = ko.observable(name);
this.custId = ko.observable(custId);
}
var viewModel = function() {
this.newUpProj = ko.observable(new Project(null,null,null));
...
}
このようなもの...私は観察可能になりたいのですnewUpProject
が、それは観察可能であるためのプロパティです。私も試しましたthis.newUpProj = ko.mapping.fromJS(new Project());
Edit1:オブジェクトを作成しますが、そのプロパティ(id、name ...)は監視可能ではありません...
Edit2:htmlで使用:
<div class="modal-body">
<p><input type="text" id="projNameTx" data-bind="value: newUpProj.name()" /></p><br>
<p><select data-bind="options: customers, optionsCaption: 'Choose...', value: newUpProj.custId(), optionsText: 'name', optionsValue: 'id'"
size="1"></select></p>
</div>
<div class="modal-footer">
<button class="btn" data-bind="click: clearModal" aria-hidden="true">Close</button>
<button class="btn btn-primary" data-bind="click: updateFlag() ? updateProject : addProject, enable: newUpProj.custId() && newUpProj.name()">Save</button>
</div>
正しい値が入力と選択に読み込まれますが、変更がモデルに適用されないため、入力が空の場合 (たとえば)、[保存] ボタンが無効になることはありません。