【问题标题】:Pass nested viewmodel in html.beginform在 html.beginform 中传递嵌套视图模型
【发布时间】: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


    【解决方案1】:

    您不能神奇地将整个模型填充到单个字段中。
    您需要为模型中的每个属性创建一个单独的隐藏字段。

    我建议将整个表单移动到一个单独的局部视图,该视图采用子模型来简化代码。

    【讨论】:

    • 好吧,这样好多了。虽然我仍然对列表属性有疑问?
    • 顺便说一句,在我获得 15 个代表之前,我无法投票赞成你的答案,但我会回来的 :)
    • @Mowgli:与其在 HTTP POST 中将列表传递回控制器,不如考虑从数据库中获取它。否则,请参阅blog.stevensanderson.com/2010/01/28/…
    猜你喜欢
    • 2014-07-14
    • 2017-04-10
    • 2016-09-06
    • 2013-05-24
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-12-01
    相关资源
    最近更新 更多