6

我想知道是否有任何方法可以像使用以下 Web 表单代码调用子布局一样静态调用视图渲染:

<sc:Sublayout Path="~/sublayouts/samplesublayouts.ascx" DataSource="SomeItemId" runat="server" />

我试过这样做:

@Html.Sitecore().ViewRendering("~/renderings/samplerendering.cshtml", new { DataSource= "SomeItemId"})

但是我不能强输入视图渲染,除非我还在 sitecore 中创建渲染项并在 sitecore 中创建模型项,因为我会收到错误。我想知道是否有一种类似的简单方式可以与 MVC 一起用于静态键入内部渲染器。

4

1 回答 1

12

下面显示的方法允许 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

执行此操作时需要注意以下几点:

  1. 剃刀视图呈现的 Sitecore 字段在页面编辑器中不可编辑。
  2. 我非常怀疑StandaloneRendering.cshtml输出是否会进入 Sitecore HTML 缓存。
  3. 应该将块中的Item属性@functions移动到某个位置,以便可以在多个剃刀视图中重用它。
  4. 这是一种非标准的方法。这可能会让一些希望在 Sitecore 中找到相关渲染项的人感到困惑。
于 2013-06-28T10:10:31.790 回答