以下是我在驗證的概念驗證(POC)的形式沒有...和它的作品。如果有人提出了一個更好的主意,我將等待將此標記爲答案。
在我的具體情況,因爲我在渲染之後調用Web API我不需要視圖模型是強類型到查找的底層實體 ...。不過,如果它可以幫助人們...我無論如何顯示PartialModel
屬性。
控制器:
public class LookupsController : Controller
{
// GET: administration/lookups/{name}
[HttpGet]
[AllowAnonymous]
public ActionResult Index(string name)
{
var viewModel = new LookupsIndexViewModel(name);
return View("index", viewModel);
}
}
視圖模型:
public class LookupsIndexViewModel
{
#region <Properties>
private const string DEFAULT_PARTIAL_PATH = "~/Areas/Administration/Views/Lookups/Partials/ProductsPartial.cshtml";
#endregion
#region <Properties>
public String PartialRelativePath { get; set; }
public PartialViewModel PartialModel { get; set; }
#endregion
#region <Constructors>
public LookupsIndexViewModel(string name)
{
Init(name);
}
#endregion
#region <Methods>
public void Init(string name)
{
PartialRelativePath = DEFAULT_PARTIAL_PATH;
// TODO: Use a factory here
if (!string.IsNullOrWhiteSpace(name))
SetPartialProperties(name);
}
///<note>You could certainly replace this functionality with a Factory object</note>
private void SetPartialProperties(string name)
{
string root = "~/Areas/Administration/Views/Lookups/Partials/";
switch (name.ToLower())
{
case "andsoon":
PartialRelativePath = root + "AndSoOnPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "areas":
PartialRelativePath = root + "AreasPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "locations":
PartialRelativePath = root + "LocationsPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "products":
PartialRelativePath = root + "ProductsPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "someotherthing":
PartialRelativePath = root + "SomeOtherThingPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "storageyards":
PartialRelativePath = root + "StorageYardsPartial.cshtml";
PartialModel = new PartialViewModel();
break;
case "yetanotherthing":
PartialRelativePath = root + "YetAnotherThingPartial.cshtml";
PartialModel = new PartialViewModel();
break;
}
}
#endregion
}
public class PartialViewModel
{
// Your awesome Strongly Typed View Model stuff goes here
}
THE VIEW:
@using Web.Areas.Administration.ViewModels
@model LookupsIndexViewModel
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>Lookups Administration</h1>
<h2 id="subTitle"></h2>
</div>
</div>
<div class="row">
<div class="col-md-3">
<!-- Sections Menu-->
<ul class="nav nav-section-menu mb-4 py-3">
<li>
@Html.ActionLink("Areas", "index", "lookups", new { area = "Administration", name = "areas" }, null)
</li>
<li>
@Html.ActionLink("Locations", "index", "lookups", new { area = "Administration", name = "locations" }, null)
</li>
<li>
@Html.ActionLink("Products", "index", "lookups", new { area = "Administration", name = "products" }, null)
</li>
<li>
@Html.ActionLink("Storage Yards", "index", "lookups", new { area = "Administration", name = "storageyards" }, null)
</li>
<li>
@Html.ActionLink("Some Other Thing", "index", "lookups", new { area = "Administration", name = "someotherthing" }, null)
</li>
<li>
@Html.ActionLink("Yet Another Thing", "index", "lookups", new { area = "Administration", name = "yetanotherthing" }, null)
</li>
<li>
@Html.ActionLink("And So On", "index", "lookups", new { area = "Administration", name = "andsoon" }, null)
</li>
</ul>
</div>
<div class="col-md-9">
@Html.Partial(Model.PartialRelativePath, Model.PartialModel)
</div>
</div>
</div>
@section scripts
{
<script type="text/javascript">
$(document).ready(function() {
onReady();
});
</script>
}
每個部分:
<div id="grid"></div>
<script type="text/javascript" defer>
// RESEARCH:
// https://stackoverflow.com/questions/7556400/injecting-content-into-specific-sections-from-a-partial-view-asp-net-mvc-3-with
var onReady = function()
{
$("#subTitle").text("And So On");
$("#grid").kendoGrid({
dataSource: {
type: "odata",
transport: {
read: "https://demos.telerik.com/kendo-ui/service/Northwind.svc/Customers"
},
pageSize: 20
},
height: 550,
groupable: true,
sortable: true,
pageable: {
refresh: true,
pageSizes: true,
buttonCount: 5
},
columns: [{
template: "<div class='customer-photo'" +
"style='background-image: url(../content/web/Customers/#:data.CustomerID#.jpg);'></div>" +
"<div class='customer-name'>#: ContactName #</div>",
field: "ContactName",
title: "Contact Name",
width: 240
}, {
field: "ContactTitle",
title: "Contact Title"
}, {
field: "CompanyName",
title: "Company Name"
}, {
field: "Country",
width: 150
}]
});
}
</script>
我不知道我這樣做是正確的,但讓我試着去了解。數據庫表是要爲每個查找共享的嗎?因爲如果是這樣,你可以爲查找創建一個Type,然後你將有一個Type for Areas,Locations,Products等等......然後你不必爲每個查找創建一個不同的動作和視圖。 –
這裏沒有顯示數據庫表 –
@PrisonerZERO我認爲「動態呈現正確的部分,當用戶點擊查詢名稱」使用AJAX是一個好主意。在這種情況下,您將不得不創建多個動作(不需要不同的控制器)並返回不同的部分,並在這些動作返回時設置查看html。創建不同的動作是一個好主意,然後在其他地方可以重用。 – User3250