利用ASP.NET的Repeater/DataList控製項來產生高Performance的TreeView效果
這篇主要介紹如何用Repeater/DataList控製項來模擬一個高效能的TreeView結果
TreeView資料庫的結構可以參考(topcat大大的blog:ASP.NET 2.0 使用資料表動態產生TreeView的樹狀結構)來設計
c#範例
treeviewRepeater.aspx
01 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="treeviewRepeater.aspx.cs"
02 Inherits="treeviewRepeater" EnableViewState="false" EnableViewStateMac="false"
03 EnableSessionState="False" %>
04
05 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
06 <html>
07 <head id="Head1" runat="server">
08 <title>Untitled Page</title>
09
10 <script language="javascript">
11 function checkAll(a,b,c)
12 {
13 alert(a+" "+b+" "+c);
14 }
15 </script>
16
17 </head>
18 <body id="body" runat="server" leftmargin="0" topmargin="0" rightmargin="0" bottommargin="0">
19 <form id="form1" runat="server">
20 <div>
21 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
22 <ItemTemplate>
23 <span style="padding-left: 0px;" />
24 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
25 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
26 <ItemTemplate>
27 <span style="padding-left: 20px;" />
28 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
29 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
30 <ItemTemplate>
31 <span style="padding-left: 40px;" />
32 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
33 </ItemTemplate>
34 </asp:Repeater>
35 </ItemTemplate>
36 </asp:Repeater>
37 </ItemTemplate>
38 </asp:Repeater>
39 <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>"
40 SelectCommand="SELECT * FROM [treeview]"></asp:SqlDataSource>
41 </div>
42 </form>
43 </body>
44 </html>
45
02 Inherits="treeviewRepeater" EnableViewState="false" EnableViewStateMac="false"
03 EnableSessionState="False" %>
04
05 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
06 <html>
07 <head id="Head1" runat="server">
08 <title>Untitled Page</title>
09
10 <script language="javascript">
11 function checkAll(a,b,c)
12 {
13 alert(a+" "+b+" "+c);
14 }
15 </script>
16
17 </head>
18 <body id="body" runat="server" leftmargin="0" topmargin="0" rightmargin="0" bottommargin="0">
19 <form id="form1" runat="server">
20 <div>
21 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
22 <ItemTemplate>
23 <span style="padding-left: 0px;" />
24 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
25 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
26 <ItemTemplate>
27 <span style="padding-left: 20px;" />
28 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
29 <asp:Repeater ID="Repeater1" runat="server" OnItemDataBound="BindLocation">
30 <ItemTemplate>
31 <span style="padding-left: 40px;" />
32 <asp:CheckBox ID="CheckBox1" runat="server" /><br />
33 </ItemTemplate>
34 </asp:Repeater>
35 </ItemTemplate>
36 </asp:Repeater>
37 </ItemTemplate>
38 </asp:Repeater>
39 <asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>"
40 SelectCommand="SELECT * FROM [treeview]"></asp:SqlDataSource>
41 </div>
42 </form>
43 </body>
44 </html>
45
treeviewRepeater.aspx.cs
01
using System;
02
using System.Data;
03
using System.Configuration;
04
using System.Collections;
05
using System.Web;
06
using System.Web.Security;
07
using System.Web.UI;
08
using System.Web.UI.WebControls;
09
using System.Web.UI.WebControls.WebParts;
10
using System.Web.UI.HtmlControls;
11data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
12
public partial class treeviewRepeater : System.Web.UI.Page
13
{
14
protected void Page_Load(object sender, EventArgs e)
15
{
16
if (!IsPostBack)
17
{
18
loadDB();
19
}
20
}
21data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
22 protected void loadDB()
23
{
24
DataTable locations = null;
25data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
26 DataView childView = null;
27data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
28 locations = ((DataView)this.SqlDataSource1.Select(DataSourceSelectArguments.Empty)).ToTable();
29data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
30 childView = new DataView(locations, "parentid = 0", "sText", DataViewRowState.CurrentRows);
31data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
32 this.Repeater1.DataSource = childView;
33data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
34 this.Repeater1.DataBind();
35
}
36data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
37 protected void BindLocation(object sender, RepeaterItemEventArgs e)
38
{
39
DataRowView locationItem = null;
40data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
41 DataTable locations = null;
42data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
43 DataView childView = null;
44data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
45 Repeater parentList = null;
46data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
47 Repeater childList = null;
48data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
49 CheckBox locationCheckBox = null;
50data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
51 if ((e.Item.ItemType == ListItemType.Item) || (e.Item.ItemType == ListItemType.AlternatingItem))
52
{
53data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
54 locationItem = (DataRowView)e.Item.DataItem;
55data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
56 locations = locationItem.DataView.Table;
57data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
58 parentList = (Repeater)sender;
59data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
60 locationCheckBox = (CheckBox)e.Item.Controls[1];
61data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
62 locationCheckBox.Text = locationItem.Row["sText"].ToString();
63data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
64 if (e.Item.Controls.Count > 3)
65
{
66data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
67 childView = new DataView(locations, "ParentId = " + locationItem.Row["NoteId"].ToString(), "sText", DataViewRowState.CurrentRows);
68data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
69 childList = (Repeater)e.Item.Controls[3];
70data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
71 childList.DataSource = childView;
72data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
73 childList.DataBind();
74data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
75 locationCheckBox.Attributes.Add("onclick", "return checkAll('" + childList.ClientID + "', '" + locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID + "', " + childList.Items.Count + ");");
76data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
77 locationCheckBox.InputAttributes.Add("ParentId", locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID);
78data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
79
}
80data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
81 else
82
{
83data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
84 locationCheckBox.Attributes.Add("onclick", "return checkAll('" + locationCheckBox.ClientID + "', '" + locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID + "', " + parentList.Items.Count + ");");
85data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
86 locationCheckBox.InputAttributes.Add("ParentId", locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID);
87data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
88
}
89data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
90
}
91
}
92
}
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
02
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
03
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
04
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
05
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
06
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
07
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
08
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
09
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
10
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
11
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
12
data:image/s3,"s3://crabby-images/bfb27/bfb27827820a5694be6d67407153a24fab45863e" alt=""
13
data:image/s3,"s3://crabby-images/951a9/951a9c99c3e9d473288a3a429857325952eefdb7" alt=""
14
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
15
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
16
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
17
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
18
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
19
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
20
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
21
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
22 protected void loadDB()
23
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
24
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
25
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
26 DataView childView = null;
27
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
28 locations = ((DataView)this.SqlDataSource1.Select(DataSourceSelectArguments.Empty)).ToTable();
29
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
30 childView = new DataView(locations, "parentid = 0", "sText", DataViewRowState.CurrentRows);
31
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
32 this.Repeater1.DataSource = childView;
33
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
34 this.Repeater1.DataBind();
35
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
36
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
37 protected void BindLocation(object sender, RepeaterItemEventArgs e)
38
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
39
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
40
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
41 DataTable locations = null;
42
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
43 DataView childView = null;
44
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
45 Repeater parentList = null;
46
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
47 Repeater childList = null;
48
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
49 CheckBox locationCheckBox = null;
50
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
51 if ((e.Item.ItemType == ListItemType.Item) || (e.Item.ItemType == ListItemType.AlternatingItem))
52
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
53
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
54 locationItem = (DataRowView)e.Item.DataItem;
55
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
56 locations = locationItem.DataView.Table;
57
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
58 parentList = (Repeater)sender;
59
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
60 locationCheckBox = (CheckBox)e.Item.Controls[1];
61
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
62 locationCheckBox.Text = locationItem.Row["sText"].ToString();
63
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
64 if (e.Item.Controls.Count > 3)
65
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
66
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
67 childView = new DataView(locations, "ParentId = " + locationItem.Row["NoteId"].ToString(), "sText", DataViewRowState.CurrentRows);
68
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
69 childList = (Repeater)e.Item.Controls[3];
70
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
71 childList.DataSource = childView;
72
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
73 childList.DataBind();
74
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
75 locationCheckBox.Attributes.Add("onclick", "return checkAll('" + childList.ClientID + "', '" + locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID + "', " + childList.Items.Count + ");");
76
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
77 locationCheckBox.InputAttributes.Add("ParentId", locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID);
78
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
79
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
80
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
81 else
82
data:image/s3,"s3://crabby-images/9e143/9e14368ed21ee82f813c16cc9a1abc7999314972" alt=""
83
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
84 locationCheckBox.Attributes.Add("onclick", "return checkAll('" + locationCheckBox.ClientID + "', '" + locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID + "', " + parentList.Items.Count + ");");
85
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
86 locationCheckBox.InputAttributes.Add("ParentId", locationCheckBox.Parent.Parent.Parent.Controls[1].ClientID);
87
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
88
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
89
data:image/s3,"s3://crabby-images/3671b/3671b64c784e720f9ec9a84daa7120d857d71b50" alt=""
90
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
91
data:image/s3,"s3://crabby-images/8205b/8205b2681b4eac0eb471ffe53696eecf47638e0c" alt=""
92
data:image/s3,"s3://crabby-images/4e083/4e083420da3c654ef1864b54dc34c6ff578f43e9" alt=""
p.s.程式碼部分由ASP.NET討論區提供
ASP.NET 2.0 Treeview control Performance