视图模型在MVC 5的回传时返回null。

3

我有一个关于ViewModel的问题,在提交视图时,所有属性的值都变成了null。

经过一番研究,我发现很多人都遇到了这个问题,我尝试了一些解决方案,但没有一个能够解决我的问题。

这是我的代码:

ViewModel:

public class EventViewModel
{
    public projectEvent ProjectEvent { get; set; }
    public List<eventType> eventTypes { get; set; }
}

控制器:

[HttpGet]
    public ActionResult AddEditEvent(int? id)
    {
        var eventViewModel = new EventViewModel();
        var projectEventModel = new projectEvent();
        if (id != null)
        {
            using (var db = new DBEntities())
            {
                projectEventModel = (from p in db.projectEvents
                                  where p.eventID == id
                                  select p).FirstOrDefault();
            }
        }

        eventViewModel.ProjectEvent = projectEventModel;

        using (var db = new DBEntities())
        {
            eventViewModel.eventTypes = (from p in db.eventTypes
                          select p).ToList();
        }

        return View(eventViewModel);
    }

    [HttpPost]
    public ActionResult AddEditEvent(EventViewModel projectEvent)
    {
        if (ModelState.IsValid)
        {
            using (var db = new DBEntities())
            {
                db.projectEvents.AddOrUpdate(projectEvent);
                db.SaveChanges();
            }
        }
        return RedirectToAction("Events");
    }

查看:

@model TTB.ViewModels.EventViewModel

@{
    Layout = "~/Views/Shared/_Layout_Main.cshtml";
}

<h2>Add/Edit Event</h2>

@using (Html.BeginForm("AddEditEvent", "Admin"))
{
    <div class="container">
        <div class="col-md-8">
            <div class="form-group">
                <label for="name">Name</label>
                @Html.TextBoxFor(m => m.ProjectEvent.eventName, new { @class = "form-control" })
                @Html.ValidationMessageFor(m => m.ProjectEvent.eventName)
            </div>
            <div class="form-group">
                <label for="name">Date</label>
                @Html.TextBoxFor(m => m.ProjectEvent.eventDate, new { @class = "form-control" })
                @Html.ValidationMessageFor(m => m.ProjectEvent.eventDate)
            </div>
            <div class="form-group">
                <label for="name">Event Type</label>
                @Html.DropDownListFor(v => v.ProjectEvent.eventType, new SelectList(Model.eventTypes, "eventTypeID", "eventTypeName"), new { @class = "form-control dropdown" })
            </div>
            @Html.HiddenFor(m => m.ProjectEvent.eventID)
        </div>
        <div class="col-md-8">
            <input type="submit" class="btn btn-success btn-lg btnSaveEdit" value="Save" />
        </div>
    </div>
}

我做错了什么?

更新

呈现的HTML输出:

<form action="/Admin/AddEditEvent" method="post">    <div class="container">
        <div class="col-md-8">
            <div class="form-group">
                <label for="name">Name</label>
                <input class="form-control" data-val="true" data-val-required="The eventName field is required." id="ProjectEvent_eventName" name="ProjectEvent.eventName" type="text" value="" />
                <span class="field-validation-valid" data-valmsg-for="ProjectEvent.eventName" data-valmsg-replace="true"></span>
            </div>
            <div class="form-group">
                <label for="name">Date</label>
                <input class="form-control" data-val="true" data-val-date="The field eventDate must be a date." data-val-required="The eventDate field is required." id="ProjectEvent_eventDate" name="ProjectEvent.eventDate" type="text" value="" />
                <span class="field-validation-valid" data-valmsg-for="ProjectEvent.eventDate" data-valmsg-replace="true"></span>
            </div>
            <div class="form-group">
                <label for="name">Event Type</label>
                <select class="form-control dropdown" id="ProjectEvent_eventType" name="ProjectEvent.eventType"><option value="1">movie</option>
</select>
            </div>
            <input data-val="true" data-val-number="The field eventID must be a number." data-val-required="The eventID field is required." id="ProjectEvent_eventID" name="ProjectEvent.eventID" type="hidden" value="0" />
        </div>
        <div class="col-md-8">
            <input type="submit" class="btn btn-success btn-lg btnSaveEdit" value="Save" />
        </div>
    </div>
</form>

1
你到底从哪里得到了空值? - globetrotter
你尝试在你的Post Action中使用ProjectEvent模型而不是EventViewModel了吗? - tmg
在您的下拉列表中,第一个参数不应该是 eventType,而应该是 v => v.ProjectEvent.eventTypes,因为在视图中,@Html.DropDownListFor 上的选定值应该传递到模型属性 eventTypes。 - vidriduch
您IP地址为143.198.54.68,由于运营成本限制,当前对于免费用户的使用频率限制为每个IP每72小时10次对话,如需解除限制,请点击左下角设置图标按钮(手机用户先点击左上角菜单按钮)。 - Pedro.The.Kid
“ProjectEvent” 属性的 HTML 渲染输出是什么? - DavidG
显示剩余3条评论
1个回答

8
因为您的模型上有一个名为projectEvent的属性,并且在将其传回控制器时,您将模型称为projectEvent。请注意修改该命名以避免混淆。
public ActionResult AddEditEvent(EventViewModel projectEvent)

To

public ActionResult AddEditEvent(EventViewModel model)
< p >(或者您选择的其他名称)< /p > < p>http://tech.pro/blog/1930/don-t-name-a-model-the-same-as-a-property-you-re-trying-bind-in-aspnet-mvc

不要将模型命名为您正在尝试绑定的属性相同的名称。这篇文章介绍了在ASP.NET MVC中避免这种情况的方法。

1
谢谢,那就是问题所在。 - Laziale

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接