IAr*_*mKs 6 asp.net-mvc sitecore sitecore6 sitecore-mvc
我想知道是否有任何方法静态调用视图渲染类似于如何使用以下Web窗体代码调用子布局:
<sc:Sublayout Path="~/sublayouts/samplesublayouts.ascx" DataSource="SomeItemId" runat="server" />
Run Code Online (Sandbox Code Playgroud)
我试过这样做:
@Html.Sitecore().ViewRendering("~/renderings/samplerendering.cshtml", new { DataSource= "SomeItemId"})
Run Code Online (Sandbox Code Playgroud)
但是我不能强烈地键入视图渲染,除非我还在sitecore中创建渲染项,并且还在sitecore中创建模型项,因为我会收到并发生错误.我想知道是否有一种类似的简单方式我可以使用MVC静态输入内部渲染器.
Kev*_*bee 12
下面显示的方法允许剃刀视图静态绑定到表示项而不创建渲染项.
在layout.cshtml
文件中静态绑定一个剃刀视图,该视图在Sitecore中没有View Rendering演示项并指定一个DataSource
项:
@Html.Sitecore().ViewRendering("/views/StandaloneRendering.cshtml", new { DataSource = "/sitecore/content/Home/My Datasource Item" })
Run Code Online (Sandbox Code Playgroud)
在StandaloneRendering.cshtml
Razor视图看起来是这样的:
@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>
Run Code Online (Sandbox Code Playgroud)
以下内容在页面上输出:
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
Run Code Online (Sandbox Code Playgroud)
这样做时需要注意以下几点:
StandaloneRendering.cshtml
输出会进入Sitecore HTML缓存.Item
属性@functions
应移动到某些位置,以便可以在多个剃刀视图中重复使用. 归档时间: |
|
查看次数: |
4299 次 |
最近记录: |