AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)

(一). 说明

用Tree显示菜单及物品列表(从服务端获取数据)比较方便,当前显示Tree 主要有两种方式:

1. 在Tree初始化时将数据全部一次性从服务端获取,获取完数据后页面展开或收缩时就不再需要获取数据,

这样,获取完数据使用时效率比较高, 但当树节点很多时, 在每次初始化时会有较大的延迟.

2. 初始化时只加载展开的节点, 当用户需要查看某个节点下的数据时, 再去取数据, 这样, 初始化时延迟会相

对减少, 但每次单击节点时要获取数据, 页面每次都要刷新, 所以也会产生延迟.

此事例用Ajax实现第二种方式, 每次只动态加载要展开的节点数据(闭合节点不展开时,则不获取其子节点的

数据), 另外加载节点时页面不会刷新.

(二). 运行示例图

AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)AjaxPro.NET框架生成高效率的Tree(Asp.net 2.0)(示例代码下载)

(三). AjaxPro.NET简介

首先对AjaxPro.NET作一下介绍, AjaxPro.NET是一个优秀的Ajax框架, 在实际应用中只要添加其DLL

引用并进行简单的配置,即可以非常方便的在客户端直接调用服务端方法, 来获取Tree节点.

(四).使用AjaxPro.NET预配置

1. 添加 AjaxPro.dll 文件的引用(示例代码中已经包含,直接COPY过来使用即可).

2. 在Web.config文件中添加以下配置,

1 < httpHandlers >
2 < addverb = " POST,GET " path = " ajaxpro/*.ashx " type = " AjaxPro.AjaxHandlerFactory,AjaxPro " />
3 </ httpHandlers >
3. 在要使用AjaxPro.NET框架的页面 *.aspx.cs 的 Page_Load事件中加如下代码:
AjaxPro.Utility.RegisterTypeForAjax( typeof (_Default));
4. 经过以上三步骤后, 只要在后台服务端的方法前面增加属性[AjaxMethod]后:
1 [AjaxMethod()] // or[AjaxPro.AjaxMethod]
2 public ArrayListGetSearchItems( string strQuery)
3 {
4 // 生成数据源
5 ArrayListitems = new ArrayList();
6 items.Add( " King " );
7 items.Add( " Rose " );
8 return items;
9 }
10
就可以在客户端直接使用服务端方法, 非常方便, 客户端调用后台代码如下:
varreturnValue = 后台代码类名.GetSearchItems(参数);

(五). 代码

1. 页面 Tree.aspx 代码:

1 <% @PageLanguage = " C# " AutoEventWireup = " true " CodeFile = " Tree.aspx.cs " Inherits = " _Default " %>
2
3 <! DOCTYPEhtmlPUBLIC " -//W3C//DTDXHTML1.0Transitional//EN " " http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd " >
4
5 < htmlxmlns = " http://www.w3.org/1999/xhtml " >
6 < headrunat = " server " >
7 < title > AjaxEfficientTree </ title >
8 < linktype = " text/css " href = " css/tree.css " rel = " stylesheet " >
9 </ head >
10 < body >
11 < formid = " form1 " runat = " server " >
12 < div >
13 < asp:PanelID = " Panel1 " runat = " server " Height = " 424px " Width = " 251px " >
14 < divid = " CategoryTree " class = " TreeMenu " ></ div >
15 </ asp:Panel >
16 < scriptlanguage = " jscript " >
17 vartree = document.getElementById( " CategoryTree " );
18 varroot = document.createElement( " li " );
19 root.id = " li_0 " ;
20 tree.appendChild(root);
21 ExpandSubCategory( 0 );
22 functionExpandSubCategory(categoryID)
23 {
24 varliFather = document.getElementById( " li_ " + categoryID);
25 if (liFather.getElementsByTagName( " li " ).length > 0 )
26 {
27 ChangeStatus(categoryID);
28 return ;
29 }
30 liFather.className = " Opened " ;
31 SwitchNode(categoryID, true );
32
33 // 仅获取当前节点的子Nodes
34 _Default.GetSubCategory(categoryID,GetSubCategory_callback);
35 }
36 functionSwitchNode(CategoryID,show)
37 {
38 varli_father = document.getElementById( " li_ " + CategoryID);
39 if (show)
40 {
41 varul = document.createElement( " ul " );
42 ul.id = " ul_note_ " + CategoryID;
43
44 varnote = document.createElement( " li " );
45 note.className = " Child " ;
46
47 varimg = document.createElement( " img " );
48 img.className = " s " ;
49 img.src = " css/s.gif " ;
50
51 vara = document.createElement( " a " );
52 a.href = " javascript:void(0); " ;
53 a.innerHTML = " Pleasewaiting " ;
54
55 note.appendChild(img);
56 note.appendChild(a);
57 ul.appendChild(note);
58 li_father.appendChild(ul);
59 }
60 else
61 {
62 varul = document.getElementById( " ul_note_ " + CategoryID);
63 if (ul)
64 {
65 li_father.removeChild(ul);
66 }
67 }
68 }
69 functionGetSubCategory_callback(response)
70 {
71 vardt = response.value.Tables[ 0 ];
72 if (dt.Rows.length > 0 )
73 {
74 variCategoryID = dt.Rows[ 0 ].FatherID;
75 }
76 varli_father = document.getElementById( " li_ " + iCategoryID);
77 varul = document.createElement( " ul " );
78 for (vari = 0 ;i < dt.Rows.length;i ++ )
79 {
80 if (dt.Rows[i].IsChild == 1 )
81 {
82 varli = document.createElement( " li " );
83 li.className = " Child " ;
84 li.id = " li_ " + dt.Rows[i].CategoryID;
85 varimg = document.createElement( " img " );
86 img.id = dt.Rows[i].CategoryID;
87 img.className = " s " ;
88 img.src = " css/s.gif " ;
89 vara = document.createElement( " a " );
90 a.href = " javascript:OpenDocument(' " + dt.Rows[i].CategoryID + " '); " ;
91 a.innerHTML = dt.Rows[i].CategoryName;
92 }
93 else
94 {
95 varli = document.createElement( " li " );
96 li.className = " Closed " ;
97 li.id = " li_ " + dt.Rows[i].CategoryID;
98 varimg = document.createElement( " img " );
99 img.id = dt.Rows[i].CategoryID;
100 img.className = " s " ;
101 img.src = " css/s.gif " ;
102 img.onclick = function(){ExpandSubCategory( this .id);};
103 img.alt = " Expand/collapse " ;
104 vara = document.createElement( " a " );
105 a.href = " javascript:ExpandSubCategory(' " + dt.Rows[i].CategoryID + " '); " ;
106 a.innerHTML = dt.Rows[i].CategoryName;
107 }
108 li.appendChild(img);
109 li.appendChild(a);
110 ul.appendChild(li);
111 }
112 li_father.appendChild(ul);
113 SwitchNode(iCategoryID, false );
114 }
115
116 // 单击叶节点时,异步从服务端获取单个节点的数据.
117 functionOpenDocument(CategoryID)
118 {
119 _Default.GetNameByCategoryID(CategoryID,GetNameByCategoryID_callback);
120 }
121
122 functionGetNameByCategoryID_callback(response)
123 {
124 alert(response.value);
125 }
126
127 functionChangeStatus(CategoryID)
128 {
129 varli_father = document.getElementById( " li_ " + CategoryID);
130 if (li_father.className == " Closed " )
131 {
132 li_father.className = " Opened " ;
133 }
134 else
135 {
136 li_father.className = " Closed " ;
137 }
138 }
139 </ script >
140 </ div >
141 </ form >
142 </ body >
143 </ html >

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 DataSetdsAllNodes = new DataSet();
15
16 protected void Page_Load( object sender,EventArgse)
17 {
18 AjaxPro.Utility.RegisterTypeForAjax( typeof (_Default));
19 CreateNodes();
20 }
21
22 private DataTableCreateStructure()
23 {
24 DataTabledt = 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 DataTabledt = this .CreateStructure();
34
35 DataRowdrNew = 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<span s
分享到:
评论

你可能感兴趣的:(.net,框架,css,asp.net,asp)