1

显然,标题采用 ImageUrl 的值

在我的 DynamicNodeProviderBase 类中同时Title配置ImageUrl

DynamicNodeProviderBase

const string keyFormated = "Subsidiary_{0}";

// Create a node for each subsidiary
foreach (var subsidiary in listDB.ToList())
{
    var node = new DynamicNode
                   {
                       Title = subsidiary.District,
                       Description = subsidiary.Title,
                       ImageUrl = Path.Combine(string.Format(Constants.RelativePathSubsidiary, subsidiary.ID.ToString().ToLower())),
                       Key = string.Format(keyFormated, subsidiary.District)
                   };
    node.RouteValues.Add("id", subsidiary.ID);
    node.Attributes.Add("LargeIconFileName", subsidiary.LargeIconFileName);
    node.Attributes.Add("MediumIconFileName", subsidiary.MediumIconFileName);
    node.Attributes.Add("SmallIconFileName", subsidiary.SmallIconFileName);
    returnValue.Add(node);
}

// Return 
return returnValue;

看法

在我看来,调用助手来生成我的页面的菜单。此菜单由 DisplayTemplates 自定义

@Html.MvcSiteMap().Menu("sitemap-menu", true, true, false)

显示模板

基本上有一个用于 的 DisplayTemplatesMenuHelperModel和一个用于SiteMapNodeModel. MenuHelperModel很简单(只需调用传递我的自定义模板的助手)@DisplayFor不会把他的代码放在这里。

以下代码SiteMapNodeModel

@model SiteMapNodeModel
@{

    object upper;
    string title = Model.Title;
    var imgUrl = Path.Combine(Model.ImageUrl, "Icons");
    string iconFilename;
    if (ViewData.TryGetValue("upper", out upper))
    {
        title = title.ToUpperInvariant();
    }

    if (Model.MetaAttributes.TryGetValue("SmallIconFileName", out iconFilename)
        || Model.MetaAttributes.TryGetValue("MediumIconFileName", out iconFilename)
        || Model.MetaAttributes.TryGetValue("LargeIconFileName", out iconFilename))
    {
        imgUrl = Path.Combine(imgUrl, iconFilename);
    }
}

@if (Model.IsCurrentNode && Model.SourceMetadata["HtmlHelper"].ToString() != "MvcSiteMapProvider.Web.Html.MenuHelper")
{ 
    <text>@title</text>
}
else if (Model.IsClickable && Model.ImageUrl != null)
{ 
    <a href="@Model.Url" title="@Model.Title">
        <img src="@Url.Content(imgUrl)" alt="@Model.Title"/>
        <span>@title</span>
    </a>
}
else
{ 
    <text>@title</text>
}

但是值不正确(或被交换)。查看调试图片:

调试

调试模式
在此处查看完整图片

注意:红色的描述是错误的:正确的是:Title 值应该在 ImageUrl 属性中!

问题

为什么ImageUrl属性的值是Title,为什么TItle是空的?

4

1 回答 1

1

这已在版本 3.2.2 中修复。这是克隆过程中的错误,错误地将 ImageUrl 映射到 Title。

于 2012-04-12T13:51:00.890 回答