3

我正在学习 ASP.NET MVC4,这是我在 Web 开发中的第一次体验。

我正在处理一种情况。在我的一个控制器中,我将 a 返回IEnumerable<BaseClass>到视图。

public class TestController : Controller
{
    public ActionResult Index()
    {
        return View(Models);
    }

    // this static method is just for demo
    static List<BaseModel> Models()
    {
        ...
    }
}

现在想象一下,我们在 BaseModels 中有 6 个具体的类。

public class ConcreteModel1 : BaseModel { .. }  // Must show view1
public class ConcreteModel2 : BaseModel { .. }  // Must show view2
public class ConcreteModel3 : BaseModel { .. }  // and so on..
public class ConcreteModel4 : BaseModel { .. }
public class ConcreteModel5 : BaseModel { .. }
public class ConcreteModel6 : BaseModel { .. }

当我想显示数据时,每个ConcrenteModel都有自己的View. 如下图所示。

在此处输入图像描述

我怎样才能做到这一点?如果我不是很清楚,请告诉我谢谢。

4

3 回答 3

5

这是一个完整的解决方案:

楷模

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace MvcApplication1.Models
{
    public abstract class BaseModel
    {
        public string Content { get; set; }
    }

    public class ConcreteModel1 : BaseModel { }
    public class ConcreteModel2 : BaseModel { }
    public class ConcreteModel3 : BaseModel { }
}

复合视图

@model System.Collections.Generic.List<MvcApplication1.Models.BaseModel>
@{
    ViewBag.Title = "CompositeView";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
<h2>
    CompositeView</h2>
@foreach (var model in Model)
{
    Html.RenderPartial(string.Format("_{0}", model.GetType().Name), model);
}

具体视图

_ConcreteModel1.cshtml

@model MvcApplication1.Models.ConcreteModel1

<h1>Concrete Model 1</h1>
@Model.Content

_ConcreteModel2.cshtml

@model MvcApplication1.Models.ConcreteModel2

<h1>Concrete Model 2</h1>
@Model.Content

_ConcreteModel3.cshtml

@model MvcApplication1.Models.ConcreteModel3

<h1>Concrete Model 3</h1>
@Model.Content

控制器

public ActionResult CompositeView()
{
    List<BaseModel> model = new List<BaseModel>();
    model.Add(new ConcreteModel1() { Content = "This is model 1." });
    model.Add(new ConcreteModel2() { Content = "This is model 2." });
    model.Add(new ConcreteModel3() { Content = "This is model 3." });

    return View(model);
}
于 2012-12-26T17:56:37.830 回答
3

您可以有一个复合视图,TestView然后为每个较小的视图渲染部分视图。为了实现这一点,需要从传递给复合视图的模型中获得较小视图的模型。

像这样的东西:(TestView.cshtml)

@model ParentViewModel

@Html.RenderPartial("View1", Model.SubModel1)
@Html.RenderPartial("View2", Model.SubModel2)
@Html.RenderPartial("View3", Model.SubModel3)

然后您有单独的视图,例如:(View1.cshtml)

@model SubViewModel1

<!-- Whatever -->
于 2012-12-26T17:44:04.823 回答
0

我实际上会创建一个自定义模型,其内容是您的IEnumerable<BaseModel>,它有自己的内置方法,用于按类型检索特定模型。这样,您可以渲染部分视图并将ConcreteModel正确输入的特定类型发送到其中。也许是这样的:

public class UltraModel
{
    // I recommend using an interface rather than a base class
    // to avoid potentially confusing types
    public IBaseModel Models { get; set; }

    public T getModelByType<T>()
    {
        return (T)Models.Where(x => x is T).FirstOrDefault();
    }
}

然后在您的全局视图中,您可以使用以下方式渲染部分:

RenderPartial("ConcreteViewName", Model.getModelByType<ConcreteModel1>());

注意:将以上内容视为伪代码。它可能需要进行调整才能正常工作。

于 2012-12-26T17:53:00.543 回答