我想知道是否有任何方法可以静态地调用视图渲染,类似于如何使用以下web窗体代码调用子布局:
<sc:Sublayout Path="~/sublayouts/samplesublayouts.ascx" DataSource="SomeItemId" runat="server" />我试过这样做:
@Html.Sitecore().ViewRendering("~/renderings/samplerendering.cshtml", new { DataSource= "SomeItemId"})但我不能强类型视图渲染,除非我还在sitecore中创建了渲染项,并且还在sitecore中创建了模型项,因为我会收到并出错。我想知道是否有一种类似的简单方法可以用于MVC,用于静态输入内部渲染器。
发布于 2013-06-28 18:10:32
下面所示的方法允许剃刀视图静态地绑定到表示项,而无需创建呈现项。
在layout.cshtml文件中,静态绑定一个在Sitecore中没有视图渲染表示项的剃刀视图,并指定一个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执行此操作时需要注意的几件事:
StandaloneRendering.cshtml输出是否会进入Sitecore HTML缓存。@functions块中的Item属性移动到某个位置,以便可以在多个剃刀视图中重用它。<代码>H215<代码>H116这是一种非标准方法。这可能会让一些希望在Sitecore中找到相关呈现项的人感到困惑。https://stackoverflow.com/questions/17352298
复制相似问题