没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|其它|编辑:郝浩|2005-02-28 09:59:00.000|阅读 1669 次
概述:
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
TreeView 控件树状控件的填充VB以及 VS.NET C#源代码
习惯了树状结构,好像很多国外网站的开发者都称之为 NETSCAPTE PER,可能是因为当时 NETSCAPTE浏览器比较时髦,而且的确也好像是它的属性最开始使用这种对话框模式
VB下面作相对比较简单一点,VC就麻烦多了。
--------------------------------------------------------------------------------
数据库:最简单的 的一个表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);
// }
// }
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号