3

このプロジェクトを使用して、サイトマップ パスを生成します。

私のアプリケーションでは、サイトマップ パスを次のように維持したいと考えています。

パス: Home > Projects > {project-name}
URL: /projects/{url-project}

パス: Home > Projects > {project-name} > Photos
URL: /projects/{url-project}/photos

パス: Home > Projects > {project-name} > Addresses
URL: /projects/{url-project}/addresses

パス: Home > Projects > {project-name} > Admin
URL: /projects/{url-project}/admin

試み

このために、私はの実装を作成しましたDynamicNodeProviderBase

public class ProjectDetailsDynamicNodeProvider : DynamicNodeProviderBase
{
    private readonly IProjectRepository _projectRepository;
    public ProjectDetailsDynamicNodeProvider()
    {
        _projectRepository = DependencyResolver.Current.GetService<IProjectRepository>();
    }

    #region Overrides of DynamicNodeProviderBase

    public override IEnumerable<DynamicNode> GetDynamicNodeCollection()
    {
        // Build value 
        var returnValue = new List<DynamicNode>();
        var listDB = (from p in _projectRepository.Query()
                      select new { p.Name, p.Keyword, p.Description });

        // Create a node for each project
        foreach (var project in listDB.ToList())
        {
            var node = new DynamicNode { Title = project.Name, Description = project.Description };
            node.RouteValues.Add("url", project.Keyword);

            returnValue.Add(node);
        }

        // Return 
        return returnValue;
    }

    #endregion
}

Mvc.サイトマップ

<mvcSiteMapNode title="Projects" controller="Project" action="Index">
  <mvcSiteMapNode title="New project" controller="Project" action="Create" />

  <mvcSiteMapNode title="Project" action="About" controller="Project" dynamicNodeProvider="BindSolution.Infra.ProjectDetailsDynamicNodeProvider, BindSolution">
    <mvcSiteMapNode title="Photos" controller="Project" action="Photos" />
    <mvcSiteMapNode title="Addresses" controller="Project" action="Addresses" />
    <mvcSiteMapNode title="Admin" controller="Project" action="Admin" />
  </mvcSiteMapNode> 
</mvcSiteMapNode>

結果

パス: Home > Projects > {project-name}
URL: /projects/{url-project}

パス: Project > Photos
URL: /projects/{url-project}/photos

パス: Project > Addresses
URL: /projects/{url-project}/addresses

パス: Project > Admin
URL: /projects/{url-project}/admin

リサーチ

インターネットを見ると、この質問がstackoverflowで見つかりましたが、解決策がよくわからないか、私の質問に当てはまりません。とにかく、これが答えなら、ソリューションの実装方法の詳細を教えていただけますか?

ご協力ありがとうございました!

4

2 に答える 2

1

私たちのコードは /country/{countryname}/ /country/{countryname}/profiles です

そして、これが私が思いついたものです。したがって、country を url-project に置き換えます。この方法で気付いている唯一の問題は、それが最善かどうかはわかりませんが、私たちの国 (210 あります) ではメモリが不足することです。私はこれを州(50)と他のいくつかで行いましたが、問題はありませんでした。国に問題がありますが、上部に 9 つの異なるページがリストされています。4にしておけば問題ありません。お役に立てれば。

public class CountriesDynamicNodeProvider : DynamicNodeProviderBase
{
    globalEDGEDataContext _db = new globalEDGEDataContext();
    public override IEnumerable<DynamicNode> GetDynamicNodeCollection()
    {
        var returnValue = new List<DynamicNode>();
        foreach (var category in _db.CountriesList().Select(a => a.Title))
        {
            DynamicNode node = new DynamicNode("country_" + Tags.MakeUrlFriendly(category), category);
            node.RouteValues.Add("country", Tags.MakeUrlFriendly(category));
            yield return node;
        }
    }
}

public class CountriesPagesDynamicNodeProvider : DynamicNodeProviderBase
{
    globalEDGEDataContext _db = new globalEDGEDataContext();
    public override IEnumerable<DynamicNode> GetDynamicNodeCollection()
    {
        foreach (var category in _db.CountriesList().Select(a=>a.Title))
        {
            DynamicNode node = new DynamicNode();
            node.Title = "Profile";
            node.ParentKey = "country_" + Tags.MakeUrlFriendly(category);
            node.RouteValues.Add("country", Tags.MakeUrlFriendly(category));
            yield return node;
        }
    }
}

この例は MVC5 でも機能します。少し変更:

  public class DepartmentEmployeeDynamicNodeProvider: DynamicNodeProviderBase
{
    AlertsContext db = new AlertsContext();

    public override IEnumerable<DynamicNode> GetDynamicNodeCollection(ISiteMapNode node)
    {
        // Build value 
        var returnValue = new List<DynamicNode>();

        // Create a node for each department 
        foreach (var department in db.Departments)
        {
            var dynNode = new DynamicNode();
            dynNode.Title = department.DepartmentName;
            dynNode.RouteValues.Add("id", department.ID);

            returnValue.Add(dynNode);
        }

        // Return 
        return returnValue; 
    }
}
于 2012-03-05T12:50:15.037 に答える
0

子ノードを親ノードの下に登録するには、親キーを割り当てるだけです。

于 2012-03-19T14:27:44.073 に答える