TreeView 控件树状控件的填充VB以及 VS.NET C#源代码 2005年2月23日09:25星期三 [Dev开发]
习惯了树状结构,好像很多国外网站的开发者都称之为 NETSCAPTE PER,可能是因为当时 NETSCAPTE浏览器比较时髦,而且的确也好像是它的属性最开始使用这种对话框模式
VB下面作相对比较简单一点,VC就麻烦多了。闲话少说,www.shengfang.org说说填充
数据库:最简单的 的一个表ss 字段:ID/NAME/PARENT,分别代表ID,名称,和父节点的ID,最高层为0
随便几个 1/W/0 2/E/1 3/R/2 4/T/1分别www.shengfang.org代表四个不同的节点。
VB就很简单了:
cmd.CommandText = "select * from ss" rs.CursorLocation = adUseClient rs.Open cmd, , adOpenDynamic, adLockOptimistic
''''ss.Nodes.Clear If rs.RecordCount <> 0 Then rs.MoveFirst End If Whwww.shengfang.orgile (rs.EOF = False) Set nodd = tv_group.Nodes.Add(, tvwLast, Str(rs!id) + "ssID", _ rs!name, 1) Debug.Print nodd.Key rs.MoveNext Wend
If rs.RecordCount <> 0 Then rs.MoveFirst End If While (rs.EOF = False) If (rs!parent <> 0) Then Set tv_group.Nodes(Str(rs!id) + "ssID").parent = tv_group.Nodes(Str( _ rs!parent) + "ssID") Else tv_grouwww.shengfang.orgp.Nodes(Str(rs!id) + "ssID").Selected = True End If rs.MoveNext Wend
rs.Close
End Sub
首先得到所有的记录,www.shengfang.org然后把记录全部填充到树控件 TREECTRL的根目录下,然后把所有父节点非0的节点的PARENT属性设置给上一个KEY为PARENT字段的节点,这样,简简单单就全部填充完毕了
VS.NET就不一样了,PARENT属性好像是只读的,只能用递归
private void InitTree() { tree.Nodes.Clear(); Cls_Phs_Node www.shengfang.orgclsnodeP=new Cls_Phs_Node("ss"); //由于TREEVIEW在.NET中的NODE节点属性好像没有KEY这个属性,所以只能自己继承一个类,扩充一个KEY clsnodeP.key="0"; tree.Nodes.Add(clsnodeP); //定义了一个根节点 OleDbDataAdapter da=new OleDbDataAdapter("select * from ss;",SQLConn); DataTable dt=new DataTable(); da.Fill(dt); da.Dispose(); FillTree(tree.Nodes[0].Nodes,"0",dt); }
//把数据库表的数据填充在根节点下面 private void FillTree(www.shengfang.orgTreeNodeCollection nodes,string parentKey,DataTable table) { foreach(DataRow dr in table.Rows) { if(dr["parent"].ToString()==parentKey.ToString()) { Cls_Phs_Node clsnode=new Cls_Phs_Node(dr["name"].ToString().Trim()); clsnode.key=dr["ID"].ToString().Trim(); clsnode.type =dr["parent"].ToString().Trim(); nodes.Add(clsnode); FillTree(clsnode.www.shengfang.orgNodes,dr["ID"].ToString(),table); } } }
不是很明白为什么VS.NET里www.shengfang.org面的TREEVIEW控件省掉了NODE的自带KEY属性以及PARENT属性变成只读的,不过没有办法。
这是网上的一个例子,用的DATAVIEW
// public void FillTree(TreeNodeCollection Nds,string parentId,DataSet ds,string TableName) // { // DataView dv=new DataView(); // TreeNode tmpNd; // string intId; // dv.Table=ds.Tables[TableName]; // dv.RowFilter="ParentId=" + parentId ; // foreach(DataRowView drv in dv) // { // tmpNd=new TreeNode(); // tmpNd.Tag =drv[0].ToString(); // tmpNd.Text=drv[2].ToString(); // Nds.Add(tmpNd); // intId=drv[1].ToString(); // InitTree(tmpNd.Nodes,tmpNd.Tag.ToString(),ds,TableName); // } // }
[系统软件]VS.net 2005 Beta 下载地址(Express Edition) [常用软件]TreeView 控件应用详解 [VB.NET程序]Henry手记-VB.NET中动态加载Treeview节点(二) [VB.NET程序]Henry手记-VB.NET中动态加载Treeview节点(一) [Delphi程序]Delphi中为TreeView添加单选和复选框 [Delphi程序]Object TreeView简要说明 [Delphi程序]Delphi下Treeview控件基于节点编号的访问 [Delphi程序]Delphi 2006(DeXter) & VS.NET 2005[原创] [VB.NET程序]将listview中显示出来的记录拖到treeview中去 [VB.NET程序]vbscript版的TreeView,也就是树
|