繁体   English   中英

MVC 4 - 如何将模型数据传递给局部视图?

[英]MVC 4 - how do I pass model data to a partial view?

我正在构建一个个人资料页面,该页面将包含许多与特定模型(租户)相关的部分 - AboutMe、MyPreferences - 诸如此类。 这些部分中的每一个都将是一个局部视图,以允许使用 AJAX 进行局部页面更新。

当我单击 TenantController 中的ActionResult时,我能够创建一个强类型视图,并将模型数据传递给视图。 我无法通过部分视图实现这一点。

我创建了一个局部视图_TenantDetailsPartial

@model LetLord.Models.Tenant
<div class="row-fluid">
    @Html.LabelFor(x => x.UserName) // this displays UserName when not in IF
    @Html.DisplayFor(x => x.UserName) // this displays nothing
</div>

然后我有一个视图MyProfile将呈现提到的部分视图:

@model LetLord.Models.Tenant
<div class="row-fluid">
    <div class="span4 well-border">
         @Html.Partial("~/Views/Tenants/_TenantDetailsPartial.cshtml", 
         new ViewDataDictionary<LetLord.Models.Tenant>())
    </div>
</div>

如果我将代码包装在 DIV 中的_TenantDetailsPartial @if(model != null){}页面上不会显示任何内容,所以我猜有一个空模型被传递给视图。

当我从ActionResult创建强类型视图时,“会话”中的用户如何传递给视图? 如何将“会话”中的用户传递到不是从ActionResult创建的部分视图? 如果我遗漏了一些关于这个概念的东西,请解释一下。

您实际上并没有将模型传递给 Partial,而是传递了一个new ViewDataDictionary<LetLord.Models.Tenant>() 试试这个:

@model LetLord.Models.Tenant
<div class="row-fluid">
    <div class="span4 well-border">
         @Html.Partial("~/Views/Tenants/_TenantDetailsPartial.cshtml", Model)
    </div>
</div>

此外,这可以使它起作用:

@{
Html.RenderPartial("your view", your_model, ViewData);
}

要么

@{
Html.RenderPartial("your view", your_model);
}

有关 MVC 中 RenderPartial 和类似 HTML 助手的更多信息,请参阅此流行的 StackOverflow 线程

将模型数据传递给局部视图的三种方式(可能还有更多)

这是查看页面

方法一在视图中填充

@{    
    PartialViewTestSOl.Models.CountryModel ctry1 = new PartialViewTestSOl.Models.CountryModel();
    ctry1.CountryName="India";
    ctry1.ID=1;    

    PartialViewTestSOl.Models.CountryModel ctry2 = new PartialViewTestSOl.Models.CountryModel();
    ctry2.CountryName="Africa";
    ctry2.ID=2;

    List<PartialViewTestSOl.Models.CountryModel> CountryList = new List<PartialViewTestSOl.Models.CountryModel>();
    CountryList.Add(ctry1);
    CountryList.Add(ctry2);    

}

@{
    Html.RenderPartial("~/Views/PartialViewTest.cshtml",CountryList );
}

方法二通过ViewBag

@{
    var country = (List<PartialViewTestSOl.Models.CountryModel>)ViewBag.CountryList;
    Html.RenderPartial("~/Views/PartialViewTest.cshtml",country );
}

方法三通过模型

@{
    Html.RenderPartial("~/Views/PartialViewTest.cshtml",Model.country );
}

在此处输入图片说明

我知道问题特定于 MVC4。 但是由于我们已经超越了 MVC4 并且如果有人在寻找ASP.NET Core ,您可以使用:

<partial name="_My_Partial" model="Model.MyInfo" />

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM