以下のようなJavaScriptコードブロックとhtmlがあります。モデル オブジェクトはジェネリックです。これは実行時に定義されます。
こんなこともありえます。
var model = { "xId": ko.observable(0), "xName": ko.observable(null), "Type": ko.observable("x") };
/* var model = { "yId": ko.observable(0), "yName": ko.observable(null), "Type": ko.observable("y") };
var model = { "zId": ko.observable(0), "zName": ko.observable(null), "Type": ko.observable("z") }; */
var vm = function (data) {
ko.mapping.fromJS(data, {}, this);
};
var vm2 = function () {
var self = this;
self.New = ko.observable(null);
self.NewItem = function () {
console.log(model);
self.New(new vm(model));
};
};
var viewModel = new vm2();
ko.applyBindings(viewModel);
vm.prototype.Save = function () {
viewModel.New(null);
/*In here all of inputs must be cleared but How to :)*/
};
最初のモデルの新しいフォーム。
<input type="button" data-bind="click: NewItem" value="Add" />
<div data-bind="with:New" id="newForm">
<input type="text" data-bind="value:xId" />
<input type="text" data-bind="value:xName" />
<input type="text" data-bind="value:Type" />
<input type="button" data-bind="click: Save" value="Save" />
</div>
追加ボタンをクリックし、入力に何か入力して、保存ボタンをクリックします。newForm は非表示です。これまでのところ、すべて問題ありません。しかし、もう一度追加ボタンをクリックすると、まだ入力に値が書かれていました。保存後に newForm をクリアできません。
編集:
public class Test{
public int TestId {get; set;}
public int TestName {get; set;}
}
public class Test2{
public int Test2Id {get; set;}
public int Test2Name {get; set;}
}
エンティティ クラスの数は明確ではありません。
私のエンティティクラスはjsonに変換されています。モデルはこのように .net で作成されます。私のプロジェクトには、マスター ページとサブページがあります。テスト ページの場合:
var model = <%=ViewModelCreator.Create<Test>() %>;
test2 ページの場合:
var model = <%=ViewModelCreator.Create<Test2>() %>;