MVCで機能する動的プレースホルダーソリューションを探しています。 WebFormsで使用するこの「パターン」には、少なくとも2つの適切な説明があります。
また、MVCでそれを行う方法を説明しているこのブログを見つけました:
最初に、MVCブログ投稿(SitecoreHelperの拡張)の手法を使用してTechphoriaのメソッド(GUIDを使用)を実装しようとしました。また、最後に説明したメソッド(Column_1、Column_2などにインクリメントされる番号サフィックスを使用)を実装しようとしました。
私が試したすべてのバリエーションで、実用的なソリューションを作成することに成功しませんでした。プレースホルダーに適切な名前が付けられません(プレースホルダーの構造がおかしくなったり、プレースホルダーが繰り返されたりしました)。
私の試みの詳細に立ち入ることなく、他の誰かが私が使用できる実用的なソリューションを用意しているかどうか知りたいです。
すでに機能している解決策が見つからない場合は、問題について詳しく説明し、それを機能させることができるかどうかを確認します。
動的プラクホルダーを作成するこの拡張機能を作成しました
public static class SitecoreHelper
{
public static HtmlString DynamicPlaceholder(this Sitecore.Mvc.Helpers.SitecoreHelper helper, string dynamicKey)
{
var currentRenderingId = RenderingContext.Current.Rendering.UniqueId;
return helper.Placeholder(string.Format("{0}_{1}", dynamicKey, currentRenderingId));
}
}
名前にGUIDを含むプレースホルダーを作成します。また、GUIDを抽出し、プレースホルダー設定を確認するステップをパイプラインに作成しました。
プレースホルダー設定を動的プレースホルダーに取得するコード@ Html.Sitecore()。DynamicPlaceholder( "test")を使用して動的プレースホルダーを作成する場合-次のコードは、testという名前のプレースホルダー設定から設定を取得します
/// <summary>
/// Handles changing context to the references dynamic "master" renderings settings for inserting the allowed controls for the placeholder and making it editable
/// </summary>
public class GetDynamicKeyAllowedRenderings : GetAllowedRenderings
{
//text that ends in a GUID
private const string DYNAMIC_KEY_REGEX = @"(.+)_[\d\w]{8}\-([\d\w]{4}\-){3}[\d\w]{12}";
public new void Process(GetPlaceholderRenderingsArgs args)
{
Assert.IsNotNull(args, "args");
string placeholderKey = args.PlaceholderKey;
Regex regex = new Regex(DYNAMIC_KEY_REGEX);
Match match = regex.Match(placeholderKey);
if (match.Success && match.Groups.Count > 0)
{
placeholderKey = match.Groups[1].Value;
}
else
{
return;
}
// Same as Sitecore.Pipelines.GetPlaceholderRenderings.GetAllowedRenderings but with fake placeholderKey
Item placeholderItem = null;
if (ID.IsNullOrEmpty(args.DeviceId))
{
placeholderItem = Client.Page.GetPlaceholderItem(placeholderKey, args.ContentDatabase,
args.LayoutDefinition);
}
else
{
using (new DeviceSwitcher(args.DeviceId, args.ContentDatabase))
{
placeholderItem = Client.Page.GetPlaceholderItem(placeholderKey, args.ContentDatabase,
args.LayoutDefinition);
}
}
List<Item> collection = null;
if (placeholderItem != null)
{
bool flag;
args.HasPlaceholderSettings = true;
collection = this.GetRenderings(placeholderItem, out flag);
if (flag)
{
args.CustomData["allowedControlsSpecified"] = true;
args.Options.ShowTree = false;
}
}
if (collection != null)
{
if (args.PlaceholderRenderings == null)
{
args.PlaceholderRenderings = new List<Item>();
}
args.PlaceholderRenderings.AddRange(collection);
}
}
}
次のコードは、ページエディタのchromeデータからGUIDを削除します
/// <summary>
/// Replaces the Displayname of the Placeholder rendering with the dynamic "parent"
/// </summary>
public class GetDynamicPlaceholderChromeData : GetChromeDataProcessor
{
//text that ends in a GUID
private const string DYNAMIC_KEY_REGEX = @"(.+)_[\d\w]{8}\-([\d\w]{4}\-){3}[\d\w]{12}";
public override void Process(GetChromeDataArgs args)
{
Assert.ArgumentNotNull(args, "args");
Assert.IsNotNull(args.ChromeData, "Chrome Data");
if ("placeholder".Equals(args.ChromeType, StringComparison.OrdinalIgnoreCase))
{
string argument = args.CustomData["placeHolderKey"] as string;
string placeholderKey = argument;
Regex regex = new Regex(DYNAMIC_KEY_REGEX);
Match match = regex.Match(placeholderKey);
if (match.Success && match.Groups.Count > 0)
{
// Is a Dynamic Placeholder
placeholderKey = match.Groups[1].Value;
}
else
{
return;
}
// Handles replacing the displayname of the placeholder area to the master reference
Item item = null;
if (args.Item != null)
{
string layout = ChromeContext.GetLayout(args.Item);
item = Sitecore.Client.Page.GetPlaceholderItem(placeholderKey, args.Item.Database, layout);
if (item != null)
{
args.ChromeData.DisplayName = item.DisplayName;
}
if ((item != null) && !string.IsNullOrEmpty(item.Appearance.ShortDescription))
{
args.ChromeData.ExpandedDisplayName = item.Appearance.ShortDescription;
}
}
}
}
}
編集
Web.configのインクルード設定は以下に含まれています。
<sitecore>
<pipelines>
<getPlaceholderRenderings>
<processor
type="YourNamespace.Pipelines.GetPlaceholderRenderings.GetDynamicKeyAllowedRenderings, YourAssembly"
patch:before="processor[@type='Sitecore.Pipelines.GetPlaceholderRenderings.GetAllowedRenderings, Sitecore.Kernel']"/>
</getPlaceholderRenderings>
<getChromeData>
<processor
type="YourNamespace.Pipelines.GetChromeData.GetDynamicPlaceholderChromeData, YourAssembly"
patch:after="processor[@type='Sitecore.Pipelines.GetChromeData.GetPlaceholderChromeData, Sitecore.Kernel']"/>
</getChromeData>
</pipelines>
</sitecore>
Integrated Dynamic Placeholders パッケージをsitecoreマーケットプレイスからダウンロードしました。ページを作成すると、プレゼンテーション層での順序に従って、プレースホルダーキーの末尾に設定可能なサフィックスが追加されたプレースホルダーがインクリメントされ、一意になります。私のために箱から出して働いた。