0

我需要填充一个treeviewinasp.net并且我需要一个递归函数来在树视图上插入所有节点和子节点。

我有两种方法:

GetRootPage()

GetPagesByParent(Page parent)-> 返回IEnumerable<Page>带有子页面的 a。

任何人都可以帮助我使用递归逻辑来构建树吗?

4

1 回答 1

1

我真诚地希望这不是一个家庭作业问题。话虽这么说,这样的事情应该让你开始:

免责声明: 我没有对此进行测试或验证,仅作为粗略示例

protected void Page_Load(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {
        var pages = GetPagesByParent(Page);
        if (pages.Count() > 0)
        {
            var roots = pages.Where(p => p.Parent == null);
            foreach (var root in roots)
            {
                //add the root nodes to the tree
                var rootNode = new TreeNode(root.Title);
                tree.Nodes.Add(rootNode);

                //kick off the recursive population
                PopulateChildNodes(pages, root, rootNode);
            }
        }
    }
}

protected void PopulateChildNodes(IEnumerable<Page> pages, Page parent, TreeNode parentNode)
{
    var childPages = pages.Where(p => p.Parent == parent);
    foreach (var page in pages)
    {
        var pageNode = new TreeNode(page.Title);
        parentNode.Nodes.Add(pageNode);

        //populate the children of the pageNode
        PopulateChildNodes(pages, page, pageNode);
    }
}
于 2012-04-24T17:20:36.953 回答