- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于ASP.NET的动态导航树的实现
摘要:该文基于在线交互教务管理系统的开发经验,利用ASP.NET提供的TreeView控件,结合SQL Server数据库表,采用深度递归遍历算法实现了动态导航树,并对算法进行了性能分析。
关键词:TreeView;数据库表;递归算法; 动态导航树
中图分类号 TP311文献标识码:A 文章编号:1009-3044(2008)28-0146-03
Achievement of Dynamic Navigation Tree Based on ASP.NET
YAO Dun-hong1,2,CHEN Shu-yu1,JIANG Qi-ming2
(1.School of Software Engineering, ChongQing University, ChongQing 400030, China;2.Department of Computer Science and Technology of Huaihua University, Hunnan 418008, China)
Abstract: This paper on the basis of the development experience of Interactive Online Educational Management System , using TreeView control provide by ASP.NET, combine SQL Server database table, adopt the depth spreading recursion algorithm has been realized dynamic navigating tree, and has carried on the analysis of performance to the algorithm.
Key words: treeView; database table;algorithm; dynamical navigation tree
1 引言
在使用ASP.NET开发基于WEB的应用系统时,用户经常希望用树状结构来显示分类或层次数据,比如网站的树形导航、管理分类导航等。使用这样的动态显示技术既简单又直观,而且方便用户访问。ASP.NET提供的TreeView服务器控件[1]就是以分层的方式向用户提供信息的,适用分层的数据集、文件夹视图以及其它类似的数据结构,可以生成用于显示分层数据的用户界面。
如何在ASP.NET下实现动态树型结构的生成,是一直以来的讨论话题,笔者结合实际开发经验,现将利用ASP.NET服务器控件TreeView结合SQL Server2000数据库设计动态树型结构的设计与实现总结如下。
2 动态导航树数据表及访问技术
与动态树相对应的树称之为静态树,静态树的生成虽然比较简单,不需要编写太多代码,但其后续维护工作比较复杂。在实际开发过程中,更好的方法是结合数据库生成动态树,实现动态绑定显示节点及增删节点。
2.1 数据库表结构设计
表1是笔者在开发在线交互教务管理系统中所设计的导航数据库表。表中的每一个元组都包含树中一个节点的信息: 主关键字NodeID是结点在树中的唯一标识; ParentID存放该节点上级节点的NodeID,其中根结点的ParentD设为0;NodeName用于节点名称,在实际应用中可用于存放希望显示在网页上的结点信息;NodeURL存放节点链接地址;Pic为显示在每个节点前的图形文件地址。
2.2 TreeView控件与数据库的连接
数据库表建好后就可在VS2005中创建树形结构页面tree.aspx,并从工具框中拖放一个树形控件,然后的工作就是对其节点数据的添加和绑定及控件事件、效果的添加和设定。
考虑到系统代码的可重用性[3],按照三层结构进行创建,所以数据层单独列出并作为一个类[4]进行创建。如DBclass.cs类,其类图如图1所示。
其中GetConnection()方法的定义如下:
public static SqlConnection GetConnection()
{ //获取数据连接语句,并创建数据库连接对象
String conn = ConfigurationManager.AppSettings[sqlconn].ToString();
SqlConnection myConn;
myConn = new SqlConnection(conn);
return myConn;
}
文档评论(0)