AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
2007-12-14 17:51
1146 查看
(一). 说明
用Tree显示菜单及物品列表(从服务端获取数据)比较方便, 当前显示Tree 主要有两种方式:
1. 在Tree初始化时将数据全部一次性从服务端获取, 获取完数据后页面展开或收缩时就不再需要获取数据,
这样, 获取完数据使用时效率比较高, 但当树节点很多时, 在每次初始化时会有较大的延迟.
2. 初始化时只加载展开的节点, 当用户需要查看某个节点下的数据时, 再去取数据, 这样, 初始化时延迟会相
对减少, 但每次单击节点时要获取数据, 页面每次都要刷新, 所以也会产生延迟.
此事例用Ajax实现第二种方式, 每次只动态加载要展开的节点数据(闭合节点不展开时,则不获取其子节点的
数据), 另外加载节点时页面不会刷新.
(二). 运行示例图
(三). AjaxPro.NET简介
首先对AjaxPro.NET作一下介绍, AjaxPro.NET是一个优秀的Ajax框架, 在实际应用中只要添加其DLL
引用并进行简单的配置, 即可以非常方便的在客户端直接调用服务端方法, 来获取Tree节点.
(四).使用AjaxPro.NET预配置
1. 添加 AjaxPro.dll 文件的引用(示例代码中已经包含,直接COPY过来使用即可).
2. 在Web.config文件中添加以下配置,
[align=center]1
2
3 [/align][align=center] [/align][align=center] [/align][align=left] 3. 在要使用AjaxPro.NET框架的页面 *.aspx.cs 的 Page_Load事件中加如下代码:[/align][align=left] [/align][align=center]AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));[/align][align=left] [/align][align=left] 4. 经过以上三步骤后, 只要在后台服务端的方法前面增加属性[AjaxMethod]后:[/align][align=left] [/align][align=center] 1 [AjaxMethod()] // or [AjaxPro.AjaxMethod]
2 public ArrayList GetSearchItems( string strQuery )
3 {
4 //生成数据源
5 ArrayList items = new ArrayList();
6 items.Add("King");
7 items.Add("Rose");
8 return items ;
9 }
10 [/align][align=left] [/align][align=left] 就可以在客户端直接使用服务端方法, 非常方便, 客户端调用后台代码如下:[/align][align=left][/align]
var returnValue = 后台代码类名.GetSearchItems(参数);(五). 代码
1. 页面 Tree.aspx 代码:
1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Tree.aspx.cs" Inherits="_Default" %>
2
3
4
5
6
7Ajax Efficient Tree
8
9
10
11
142
143 2. 页面后台文件 Tree.aspx.cs 代码:
1 using System;
2 using System.Data;
3 using System.Configuration;
4 using System.Web;
5 using System.Web.Security;
6 using System.Web.UI;
7 using System.Web.UI.WebControls;
8 using System.Web.UI.WebControls.WebParts;
9 using System.Web.UI.HtmlControls;
10
11 public partial class _Default : System.Web.UI.Page
12 {
13 //此对象用于存放所有的节点数
14 public static DataSet dsAllNodes = new DataSet();
15
16 protected void Page_Load(object sender, EventArgs e)
17 {
18 AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));
19 CreateNodes();
20 }
21
22 private DataTable CreateStructure()
23 {
24 DataTable dt = new DataTable();
25 dt.Columns.Add(new DataColumn("CategoryID", typeof(int)));
26 dt.Columns.Add(new DataColumn("CategoryName", typeof(string)));
27 dt.Columns.Add(new DataColumn("FatherID", typeof(string)));
28 dt.Columns.Add(new DataColumn("IsChild", typeof(bool)));
29 return dt;
30 }
31 public void CreateNodes()
32 {
33 DataTable dt = this.CreateStructure();
34
35 DataRow drNew = dt.NewRow();
36 drNew["CategoryID"] = 1;
37 drNew["CategoryName"] = "物品类别";
38 drNew["FatherID"] = 0;
39 dt.Rows.Add( drNew );
40
41 drNew = dt.NewRow();
42 drNew["CategoryID"] = 2;
43 drNew["CategoryName"] = "水果";
44 drNew["FatherID"] = 1;
45 dt.Rows.Add( drNew );
46
47 drNew = dt.NewRow();
48 drNew["CategoryID"] = 3;
49 drNew["CategoryName"] = "工具";
50 drNew["FatherID"] = 1;
51 dt.Rows.Add( drNew );
52
53 drNew = dt.NewRow();
54 drNew["CategoryID"] = 4;
55 drNew["CategoryName"] = "萍果";
56 drNew["FatherID"] = 2;
57 dt.Rows.Add( drNew );
58
59 drNew = dt.NewRow();
60 drNew["CategoryID"] = 5;
61 drNew["CategoryName"] = "香蕉";
62 drNew["FatherID"] = 2;
63 dt.Rows.Add( drNew );
64
65 drNew = dt.NewRow();
66 drNew["CategoryID"] = 6;
67 drNew["CategoryName"] = "桔子";
68 drNew["FatherID"] = 2;
69 dt.Rows.Add( drNew );
70
71 drNew = dt.NewRow();
72 drNew["CategoryID"] = 7;
73 drNew["CategoryName"] = "萝卜";
74 drNew["FatherID"] = 2;
75 dt.Rows.Add( drNew );
76
77 drNew = dt.NewRow();
78 drNew["CategoryID"] = 8;
79 drNew["CategoryName"] = "钢笔";
80 drNew["FatherID"] = 3;
81 dt.Rows.Add( drNew );
82
83 drNew = dt.NewRow();
84 drNew["CategoryID"] = 9;
85 drNew["CategoryName"] = "铅笔";
86 drNew["FatherID"] = 3;
87 dt.Rows.Add( drNew );
88
89 drNew = dt.NewRow();
90 drNew["CategoryID"] = 10;
91 drNew["CategoryName"] = "尺子";
92 drNew["FatherID"] = 3;
93 dt.Rows.Add( drNew );
94
95 drNew = dt.NewRow();
96 drNew["CategoryID"] = 11;
97 drNew["CategoryName"] = "橡皮";
98 drNew["FatherID"] = 3;
99 dt.Rows.Add( drNew );
100
101 dsAllNodes.Tables.Add(dt);
102 }
103
104 [AjaxPro.AjaxMethod]
105 public DataSet GetSubCategory(int CategoryID)
106 {
107 DataSet ds = new DataSet();
108 DataTable dt = this.CreateStructure();
109 DataRow[] drSelect = dsAllNodes.Tables[0].Select("FatherID=" + CategoryID.ToString());
110 foreach (DataRow drTemp in drSelect)
111 {
112 DataRow dr = dt.NewRow();
113 dr["CategoryID"] = drTemp["CategoryID"];
114 dr["CategoryName"] = drTemp["CategoryName"];
115 dr["FatherID"] = drTemp["FatherID"];
116 dr["IsChild"] = IsLeaf( int.Parse( drTemp["CategoryID"].ToString() ) );
117 dt.Rows.Add(dr);
118 }
119 ds.Tables.Add(dt);
120 return ds;
121 }
122
123 [AjaxPro.AjaxMethod]
124 public bool IsLeaf(int Category)
125 {
126 foreach(DataRow dr in dsAllNodes.Tables[0].Rows)
127 {
128 if (dr["FatherID"] != null && int.Parse(dr["FatherID"].ToString()) == Category)
129 {
130 return false;
131 }
132 }
133 return true;
134 }
135
136 [AjaxPro.AjaxMethod]
137 public string GetNameByCategoryID(string CategoryID )
138 {
139 foreach( DataRow dr in dsAllNodes.Tables[0].Rows )
140 {
141 if( dr["CategoryID"].ToString() == CategoryID.ToString() )
142 {
143 return dr["CategoryName"].ToString();
144 }
145 }
146 return "";
147 }
148 }(六). 示例代码下载:
http://www.cnitblog.com/Files/ChengKing/AjaxPro.net_EfficientTree.rar
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1128545
用Tree显示菜单及物品列表(从服务端获取数据)比较方便, 当前显示Tree 主要有两种方式:
1. 在Tree初始化时将数据全部一次性从服务端获取, 获取完数据后页面展开或收缩时就不再需要获取数据,
这样, 获取完数据使用时效率比较高, 但当树节点很多时, 在每次初始化时会有较大的延迟.
2. 初始化时只加载展开的节点, 当用户需要查看某个节点下的数据时, 再去取数据, 这样, 初始化时延迟会相
对减少, 但每次单击节点时要获取数据, 页面每次都要刷新, 所以也会产生延迟.
此事例用Ajax实现第二种方式, 每次只动态加载要展开的节点数据(闭合节点不展开时,则不获取其子节点的
数据), 另外加载节点时页面不会刷新.
(二). 运行示例图
(三). AjaxPro.NET简介
首先对AjaxPro.NET作一下介绍, AjaxPro.NET是一个优秀的Ajax框架, 在实际应用中只要添加其DLL
引用并进行简单的配置, 即可以非常方便的在客户端直接调用服务端方法, 来获取Tree节点.
(四).使用AjaxPro.NET预配置
1. 添加 AjaxPro.dll 文件的引用(示例代码中已经包含,直接COPY过来使用即可).
2. 在Web.config文件中添加以下配置,
[align=center]1
2
3
2 public ArrayList GetSearchItems( string strQuery )
3 {
4 //生成数据源
5 ArrayList items = new ArrayList();
6 items.Add("King");
7 items.Add("Rose");
8 return items ;
9 }
10 [/align][align=left] [/align][align=left] 就可以在客户端直接使用服务端方法, 非常方便, 客户端调用后台代码如下:[/align][align=left][/align]
var returnValue = 后台代码类名.GetSearchItems(参数);(五). 代码
1. 页面 Tree.aspx 代码:
1 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Tree.aspx.cs" Inherits="_Default" %>
2
3
4
5
6
7
8
9
10
11
142
143 2. 页面后台文件 Tree.aspx.cs 代码:
1 using System;
2 using System.Data;
3 using System.Configuration;
4 using System.Web;
5 using System.Web.Security;
6 using System.Web.UI;
7 using System.Web.UI.WebControls;
8 using System.Web.UI.WebControls.WebParts;
9 using System.Web.UI.HtmlControls;
10
11 public partial class _Default : System.Web.UI.Page
12 {
13 //此对象用于存放所有的节点数
14 public static DataSet dsAllNodes = new DataSet();
15
16 protected void Page_Load(object sender, EventArgs e)
17 {
18 AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));
19 CreateNodes();
20 }
21
22 private DataTable CreateStructure()
23 {
24 DataTable dt = new DataTable();
25 dt.Columns.Add(new DataColumn("CategoryID", typeof(int)));
26 dt.Columns.Add(new DataColumn("CategoryName", typeof(string)));
27 dt.Columns.Add(new DataColumn("FatherID", typeof(string)));
28 dt.Columns.Add(new DataColumn("IsChild", typeof(bool)));
29 return dt;
30 }
31 public void CreateNodes()
32 {
33 DataTable dt = this.CreateStructure();
34
35 DataRow drNew = dt.NewRow();
36 drNew["CategoryID"] = 1;
37 drNew["CategoryName"] = "物品类别";
38 drNew["FatherID"] = 0;
39 dt.Rows.Add( drNew );
40
41 drNew = dt.NewRow();
42 drNew["CategoryID"] = 2;
43 drNew["CategoryName"] = "水果";
44 drNew["FatherID"] = 1;
45 dt.Rows.Add( drNew );
46
47 drNew = dt.NewRow();
48 drNew["CategoryID"] = 3;
49 drNew["CategoryName"] = "工具";
50 drNew["FatherID"] = 1;
51 dt.Rows.Add( drNew );
52
53 drNew = dt.NewRow();
54 drNew["CategoryID"] = 4;
55 drNew["CategoryName"] = "萍果";
56 drNew["FatherID"] = 2;
57 dt.Rows.Add( drNew );
58
59 drNew = dt.NewRow();
60 drNew["CategoryID"] = 5;
61 drNew["CategoryName"] = "香蕉";
62 drNew["FatherID"] = 2;
63 dt.Rows.Add( drNew );
64
65 drNew = dt.NewRow();
66 drNew["CategoryID"] = 6;
67 drNew["CategoryName"] = "桔子";
68 drNew["FatherID"] = 2;
69 dt.Rows.Add( drNew );
70
71 drNew = dt.NewRow();
72 drNew["CategoryID"] = 7;
73 drNew["CategoryName"] = "萝卜";
74 drNew["FatherID"] = 2;
75 dt.Rows.Add( drNew );
76
77 drNew = dt.NewRow();
78 drNew["CategoryID"] = 8;
79 drNew["CategoryName"] = "钢笔";
80 drNew["FatherID"] = 3;
81 dt.Rows.Add( drNew );
82
83 drNew = dt.NewRow();
84 drNew["CategoryID"] = 9;
85 drNew["CategoryName"] = "铅笔";
86 drNew["FatherID"] = 3;
87 dt.Rows.Add( drNew );
88
89 drNew = dt.NewRow();
90 drNew["CategoryID"] = 10;
91 drNew["CategoryName"] = "尺子";
92 drNew["FatherID"] = 3;
93 dt.Rows.Add( drNew );
94
95 drNew = dt.NewRow();
96 drNew["CategoryID"] = 11;
97 drNew["CategoryName"] = "橡皮";
98 drNew["FatherID"] = 3;
99 dt.Rows.Add( drNew );
100
101 dsAllNodes.Tables.Add(dt);
102 }
103
104 [AjaxPro.AjaxMethod]
105 public DataSet GetSubCategory(int CategoryID)
106 {
107 DataSet ds = new DataSet();
108 DataTable dt = this.CreateStructure();
109 DataRow[] drSelect = dsAllNodes.Tables[0].Select("FatherID=" + CategoryID.ToString());
110 foreach (DataRow drTemp in drSelect)
111 {
112 DataRow dr = dt.NewRow();
113 dr["CategoryID"] = drTemp["CategoryID"];
114 dr["CategoryName"] = drTemp["CategoryName"];
115 dr["FatherID"] = drTemp["FatherID"];
116 dr["IsChild"] = IsLeaf( int.Parse( drTemp["CategoryID"].ToString() ) );
117 dt.Rows.Add(dr);
118 }
119 ds.Tables.Add(dt);
120 return ds;
121 }
122
123 [AjaxPro.AjaxMethod]
124 public bool IsLeaf(int Category)
125 {
126 foreach(DataRow dr in dsAllNodes.Tables[0].Rows)
127 {
128 if (dr["FatherID"] != null && int.Parse(dr["FatherID"].ToString()) == Category)
129 {
130 return false;
131 }
132 }
133 return true;
134 }
135
136 [AjaxPro.AjaxMethod]
137 public string GetNameByCategoryID(string CategoryID )
138 {
139 foreach( DataRow dr in dsAllNodes.Tables[0].Rows )
140 {
141 if( dr["CategoryID"].ToString() == CategoryID.ToString() )
142 {
143 return dr["CategoryName"].ToString();
144 }
145 }
146 return "";
147 }
148 }(六). 示例代码下载:
http://www.cnitblog.com/Files/ChengKing/AjaxPro.net_EfficientTree.rar
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1128545
相关文章推荐
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- [导入]AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- [导入]AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- [转]AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)
- AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载) [转]
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- [导入]ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)
- ASP.NET 2.0 HttpHandler实现生成图片验证码(示例代码下载)