我有一个定义好的主要形式,它可以做它需要做的事情......
@{ Html.BeginForm(); }
@Html.ValidationSummary(false)
@Html.AntiForgeryToken()
@Html.EditorFor(model => model)
<h2>Properties</h2>
<hr />
@* I want to put some stuff here... *@
<br class="space" />
<div class="clearfix">>
<button type="submit" data-bind="click: save">
Save
</button>
</div>
@{ Html.EndForm(); }
接着。这个模型(或者更确切地说是 ViewModel)有一个IList<PropertyViewModel>
附加的。
APropertyViewModel
有自己的一组验证。它们现在非常简单,但以后可能会对此设置有更复杂的用途。
我正在使用KnockoutJS
我的 viewModel 一致性。虽然我认为这是相当无关紧要的。我想在 a 中显示第二种形式jQuery UI Dialog
并返回结果,本质上是..
<script type="text/javascript">
var viewModel = {
name: ko.observable(),
description: ko.observable(),
properties: ko.observableArray(),
save: function () {
alert(ko.toJSON(viewModel));
},
includeProperty: function () {
$("#dialog").dialog({
width: 500,
closeText: '',
resizable: true,
buttons: {
'Submit': function () {
$(this).dialog('close');
callback( @* I want the new data to get sent back *@ );
},
'Cancel': function () {
$(this).dialog('close');
return false;
}
}
});
}
};
function callback(value) {
alert(ko.toJSON(value)); // (I will push the new property to the viewmodel here)
}
ko.applyBindings(viewModel);
</script>
但是,我不确定如何将其实际放入EditorTemplate
对话框中,而且我不确定如何从中取回数据。