使用ImageUrl DynamicNodeProviderBase的问题

时间:2012-02-04 19:19:12

标签: asp.net-mvc-3 sitemap mvcsitemapprovider sitemapprovider

显然,标题采用ImageUrl的值

在我的DynamicNodeProviderBase类中配置TitleImageUrl

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)

DisplayTemplates

基本上有MenuHelperModel的DisplayTemplates和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>
}

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

调试

Debug mode
full image here

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

问题

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

1 个答案:

答案 0 :(得分:1)

版本3.2.2中已修复此问题。 在克隆过程中出错,将ImageUrl错误地映射到Title。