【发布时间】:2011-05-12 13:59:25
【问题描述】:
我有一个问题,我有一个带有嵌套视图模型 (ChildViewModel) 的视图模型 (MasterViewModel),并且我在表单中有一个下拉列表,它通过 jQuery 执行 ajax 发布以更新部分视图。但是不管我做什么,Part动作中的childviewmodel总是空的,我不明白为什么。这是一个简化的代码示例:
控制器:
Namespace MvcApplication2
Public Class TestController
Inherits System.Web.Mvc.Controller
'
' GET: /Test
Function Index() As ActionResult
Dim viewModel As New MasterViewModel
viewModel.MyId = 123
viewModel.ChildViewModel = New ChildViewModel With {.Name = "woohoo"}
viewModel.Items = New List(Of SelectListItem) From { _
New SelectListItem With {.Text = "first", .Value = "1"},
New SelectListItem With {.Text = "second", .Value = "2"}
}
viewModel.SelectedItem = New List(Of SelectListItem) From { _
New SelectListItem With {.Text = "first", .Value = "1"}
}
Return View(viewModel)
End Function
Function Part(ByVal viewModel As ChildViewModel) As ActionResult
viewModel.Name = viewModel.Name & "_"
Return PartialView(viewModel)
End Function
End Class
End Namespace
索引视图:
@ModelType MvcApplication2.MasterViewModel
@Code
ViewData("Title") = "Index"
End Code
<script type="text/javascript" language="javascript">
function update() {
$('#myForm').change(function () {
var form = $('#myForm');
$.ajax({
url: form.attr('action'),
type: form.attr('method'),
data: form.serialize(),
success: function (result) {
$('#mjoo').html(result);
}
});
});
}
</script>
<h2>Index</h2>
<p>@Model.MyId</p>
@Using Html.BeginForm("Part", "Test", FormMethod.Post, New With {.id = "myForm"})
@Html.DropDownListFor(Function(x) x.SelectedItem, Model.Items, New With {.onchange = "update()"})
@Html.HiddenFor(Function(x) x.ChildViewModel)
End Using
<div id="mjoo">
@Html.Partial("Part", Model.ChildViewModel)
</div>
部分视图:
@ModelType MvcApplication2.ChildViewModel
<p>@Model.Name</p>
视图模型:
Public Class MasterViewModel
Property ChildViewModel As ChildViewModel
Property Items As List(Of SelectListItem)
Property SelectedItem As List(Of SelectListItem)
Property MyId As Integer
End Class
Public Class ChildViewModel
Property Name As String
End Class
这可能有什么问题。我知道我缺少某些东西,但我就是看不到它。
【问题讨论】:
标签: asp.net-mvc razor viewmodel