首页级视图命名为“ Create.cshtml”
在该页面上,我需要放置多个使用剃须刀页面制作的_partialViews.cshtml:
<div>
<row>
<div class="col-md-6">
@await Html.PartialAsync("~/Views/Shared/_PartialDelegates")
</div>
<div class="col-md-6">
@await Html.PartialAsync("~/Views/Shared/_PartialApps")
</div>
</row>
</div>
现在的问题是我正在尝试通过_PartialDelegates.cs调用_PartialDelegates.cshtml
_PartialDelegates.cshtml
@page
@model IMP.ECR.WEB.Views.Shared._PartialDelegatesModel
@{
}
<partial name="_PartialDelegatesView" model="Model.Avengers" />
调用_PartialDelegates.cshtml.cs
using Microsoft.AspNetCore.Mvc.RazorPages;
namespace IMP.ECR.WEB.Views.Shared
{
public class _PartialDelegatesModel : PageModel
{
public List<string> Avengers = new List<string>();
public void OnGet()
{
Avengers.AddRange(new[] { "Spiderman", "Iron Man", "Dr. Stange", "The Hulk" });
}
}
}
}
然后在_PartialDelegatesView.cshtml中,我具有以下内容:
@model List<string>
<div class="col-md-12">
<h2>Avengers</h2>
<table class="table table-boardered table-striped" style="width:100%">
@foreach (var item in Model)
{
<tr>
<td>@item</td>
</tr>
}
</table>
</div>
但是,我一直收到未处理的异常---
An unhandled exception occurred while processing the request.
NullReferenceException: Object reference not set to an instance of an
object.
AspNetCore.Views_Shared__PartialDelegates.get_Model()
NullReferenceException: Object reference not set to an instance of an object.
AspNetCore.Views_Shared__PartialDelegates.get_Model()
AspNetCore.Views_Shared__PartialDelegates.ExecuteAsync() in _PartialDelegates.cshtml
+
<partial name="_PartialDelegatesView" model="Model.Avengers" />
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderPageCoreAsync(IRazorPage page, ViewContext context)
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderPageAsync(IRazorPage page, ViewContext context, bool invokeViewStarts)
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderAsync(ViewContext context)
Microsoft.AspNetCore.Mvc.ViewFeatures.HtmlHelper.RenderPartialCoreAsync(string partialViewName, object model, ViewDataDictionary viewData, TextWriter writer)
Microsoft.AspNetCore.Mvc.ViewFeatures.HtmlHelper.PartialAsync(string partialViewName, object model, ViewDataDictionary viewData)
AspNetCore.Views_Sponsors_Create.ExecuteAsync() in Create.cshtml
+
@await Html.PartialAsync("~/Views/Shared/_PartialDelegates.cshtml")
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderPageCoreAsync(IRazorPage page, ViewContext context)
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderPageAsync(IRazorPage page, ViewContext context, bool invokeViewStarts)
Microsoft.AspNetCore.Mvc.Razor.RazorView.RenderAsync(ViewContext context)
Microsoft.AspNetCore.Mvc.ViewFeatures.ViewExecutor.ExecuteAsync(ViewContext viewContext, string contentType, Nullable<int> statusCode)
Microsoft.AspNetCore.Mvc.ViewFeatures.ViewExecutor.ExecuteAsync(ActionContext actionContext, IView view, ViewDataDictionary viewData, ITempDataDictionary tempData, string contentType, Nullable<int> statusCode)
Microsoft.AspNetCore.Mvc.ViewFeatures.ViewResultExecutor.ExecuteAsync(ActionContext context, ViewResult result)
Microsoft.AspNetCore.Mvc.ViewResult.ExecuteResultAsync(ActionContext context)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeResultAsync(IActionResult result)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeNextResultFilterAsync<TFilter, TFilterAsync>()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Rethrow(ResultExecutedContext context)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.ResultNext<TFilter, TFilterAsync>(ref State next, ref Scope scope, ref object state, ref bool isCompleted)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeResultFilters()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeNextResourceFilter()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Rethrow(ResourceExecutedContext context)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.Next(ref State next, ref Scope scope, ref object state, ref bool isCompleted)
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeFilterPipelineAsync()
Microsoft.AspNetCore.Mvc.Internal.ResourceInvoker.InvokeAsync()
Microsoft.AspNetCore.Builder.RouterMiddleware.Invoke(HttpContext httpContext)
Microsoft.AspNetCore.StaticFiles.StaticFileMiddleware.Invoke(HttpContext context)
Microsoft.AspNetCore.Diagnostics.DeveloperExceptionPageMiddleware.Invoke(HttpContext context)
答案 0 :(得分:1)
将Razor页面作为局部视图加载似乎是不可能的,请参考here。
不能使用剃须刀页面代替View Components。请按照以下步骤创建一个PartialDelegates
ViewComponent,它可以完成您想做的事情。
1。创建一个ViewComponens
文件夹,并在该文件夹中添加一个PartialDelegates.cs
类
public class PartialDelegates:ViewComponent
{
public IViewComponentResult Invoke()
{
List<string> Avengers = new List<string>();
Avengers.AddRange(new[] { "Spiderman", "Iron Man", "Dr. Stange", "The Hulk" });
return View(Avengers);
}
}
2。将Default.cshtml
添加到路径/Views/Shared/Components/PartialDelegates/Default.cshtml
(如果不存在则创建文件夹)
@model List<string>
<h1>Default</h1>
<partial name="_PartialDelegatesView" model="Model" />
3。在您的Create.cshtml中,调用视图组件
@await Component.InvokeAsync("PartialDelegates")
答案 1 :(得分:0)
您需要删除@page
中的_PartialDelegates.cshtml
指令以使部分视图正常工作。但是问题在于_PartialDelegatesModel
OnGet
方法从未被调用,因此Avengers
列表未实例化。
似乎不可能将这样的剃刀页面用作部分视图,只有常规的剃刀视图适合于此目的。如果您需要在呈现页面之前实例化一些值,请按照docs ("Important" section)
如果需要执行代码,请使用view component而不是局部视图。