我有一页:

<%@ Page Inherits="System.Web.Mvc.View<DTOSearchResults>" %>

上面写着:

<% Html.RenderPartial("TaskList", Model.Tasks); %>

下面是DTO对象:

public class DTOSearchResults
{
    public string SearchTerm { get; set; }
    public IEnumerable<Task> Tasks { get; set; }

这是偏导数:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<IEnumerable<Task>>" %>

当模型。Tasks不是空的,一切正常。然而,当它为空时,我得到:

传递到字典中的模型项是类型的 'DTOSearchResults'但是这个字典需要一个类型的模型项 “System.Collections.Generic.IEnumerable”1[任务]”。

我认为它一定不知道使用哪个重载,所以我这样做(见下文)是明确的,但我仍然得到相同的问题!

<% Html.RenderPartial("TaskList", (object)Model.Tasks, null); %>

我知道我可以通过检查null来解决这个问题,甚至不传递null,但这不是重点。为什么会这样?


当前回答

我的解决方法是:


<% Html.RenderPartial("TaskList", Model.Tasks ?? new List()); %>

其他回答

当你传入的模型的属性为空时,MVC会有意地返回到“父”模型。显然,MVC引擎将空模型值解释为使用前一个值的意图。

这里稍微详细一些:NET MVC,强类型视图,部分视图参数故障

我的解决方法是:


<% Html.RenderPartial("TaskList", Model.Tasks ?? new List()); %>

@myandmycode的答案很好,但稍微短一点的答案会是

<% Html.RenderPartial("TaskList", new ViewDataDictionary(Model.Tasks)); %>

这是可行的,因为viewdatdictionary是保存模型的东西,它可以接受模型作为构造函数参数。这基本上传递了一个“完整的”视图数据字典,其中当然只包含可能为空的模型。

Andrew我认为你得到的问题是RenderPartial方法使用调用(视图)的模型到局部视图的结果,当你传递的模型是空的。你可以通过以下方法来避免这种奇怪的行为:

<% Html.RenderPartial("TaskList", Model.Tasks, new ViewDataDictionary()); %>

这有用吗?

如果你不想在局部视图中丢失之前的ViewData,你可以尝试:

<% Html.RenderPartial("TaskList", Model.Tasks, new ViewDataDictionary(ViewData){Model = null});%>