下面显示的方法允许 razor 视图静态绑定到表示项,而无需创建渲染项。
在layout.cshtml
文件中静态绑定一个在 Sitecore 中没有 View Rendering 演示项目的 razor 视图并指定一个DataSource
项目:
@Html.Sitecore().ViewRendering("/views/StandaloneRendering.cshtml", new { DataSource = "/sitecore/content/Home/My Datasource Item" })
StandaloneRendering.cshtml
剃刀视图如下所示:
@using Sitecore.Mvc.Presentation
@model RenderingModel
@functions
{
public Sitecore.Data.Items.Item Item
{
get
{
var item = Sitecore.Context.Item;
if (!string.IsNullOrEmpty(Model.Rendering.DataSource))
{
item = Sitecore.Context.Database.GetItem(Model.Rendering.DataSource);
}
return item;
}
}
}
<p>Item Name: @Model.PageItem.Name</p>
<p>Datasource Path: @Model.Rendering.DataSource</p>
<p>Datasource Item Name: @Item.Name</p>
<p>Datasource Item Path: @Item.Paths.FullPath</p>
<p>Datasource Item Template: @Item.TemplateName</p>
以下内容在页面上得到输出:
Item Name: Home
Datasource Path: /sitecore/content/Home/My Datasource Item
Datasource Item Name: My Datasource Item
Datasource Item Path: /sitecore/content/Home/My Datasource Item
Datasource Item Template: Sample Item
执行此操作时需要注意以下几点:
- 剃刀视图呈现的 Sitecore 字段在页面编辑器中不可编辑。
- 我非常怀疑
StandaloneRendering.cshtml
输出是否会进入 Sitecore HTML 缓存。
- 应该将块中的
Item
属性@functions
移动到某个位置,以便可以在多个剃刀视图中重用它。
- 这是一种非标准的方法。这可能会让一些希望在 Sitecore 中找到相关渲染项的人感到困惑。