创建一个treeview c#asp.net - 展开所有节点

时间:2012-02-20 13:43:12

标签: c# asp.net architecture treeview nodes

我在尝试使用asp.net和c#构建树视图时遇到问题。

我的结果是试图显示这样的树视图(抱歉错误的拼写或错误的位置,但这只是测试数据):

UK 
   -> London
     -> SouthEast
        ->Kent
        ->Essex
     -> NorthEast
        ->Cambridge
Wales
   -> Cardiff

以下是我的代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="WebApplication1.WebForm1"
    ValidateRequest="false" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <asp:TreeView ID="TreeView1" runat="server" >
                </asp:TreeView>
    </form>
</body>
</html>

C#:

using System;
using System.Collections.Generic;
using System.Web.UI.WebControls;
using System.Collections.ObjectModel;

namespace WebApplication1
{  
    public partial class WebForm1 : System.Web.UI.Page
    {
        public class ViewModel
        {           
            public string LocationName { get; set; }           
        }
        protected void Page_Load(object sender, EventArgs e)
        {
            ICollection<ViewModel> list = new Collection<ViewModel>();
            list.Add(new ViewModel { LocationName = "UK" });
            list.Add(new ViewModel { LocationName = "UK.London.SouthEast.Kent" });
            list.Add(new ViewModel { LocationName = "UK.London.SouthEast.Essex" });
            list.Add(new ViewModel { LocationName = "Wales.Cardiff" });
            list.Add(new ViewModel { LocationName = "Wales" });
            list.Add(new ViewModel { LocationName = "UK.London.NorthEast.Cambridge" });

            PopulateTreeview(list);
        }

        private void PopulateTreeview(ICollection<ViewModel> listOfCities)
        {
            foreach (ViewModel vm in listOfCities)
            {
                    TreeNode tnNode = new TreeNode();
                    tnNode.Text = vm.LocationName;
                    tnNode.Value = vm.LocationName;                    
                    tnNode.Expanded = true;                   
                    TreeView1.Nodes.Add(tnNode);                
            }
        }
    }
}

正如您所看到的,我的测试数据是这种格式“UK.London.SouthEast.Essex”。我将从DB获取此数据。我需要使用这些数据构建父节点和子节点,但不知道如何?几天来一直在努力写下如何做到这一点。

1 个答案:

答案 0 :(得分:2)

您正在填充TreeView,就像它是List一样。您需要指定层次结构才能正确填充树...

看看: http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.treenode.childnodes.aspx

每个节点都应添加其各自的子节点。另一方面,您指定所有节点都应放在“根”下。