引言:
參與了一個大型社區程序的開發,現在將相關開發經驗陸續總結出來,和大家探討一下。本節內容主要主要討論的是用TreeView生成無限級分類的樹型目錄的問題,相關代碼摘錄自社區程序中的一個文章發布管理系統中的目錄管理部分。
一、數據庫設計
BBS_BestArticleFolder 精華區目錄表 Key: FolderID Field name Type Length Default Description FolderID int 4 ID(自動編號) ParentFolderID int 4 0 父目錄ID FolderName Nvarchar 80 目錄名 BoardID int 4 0 版塊ID CreaterUserID int 4 0 創建者ID AddTime DateTime 8 GetDate() 創建時間
二、樹型目錄構建過程
1、安裝TreeView控件,我想大多數人都是會安裝的,不會安裝的去找相關文章一下下。
2、具體實現:
a 數據生成
#region 樹的數據生成事件
private DataView CreateDateView(int boardID)
{
BBSBestArticleFolderCollection bafc=new BBSBestArticleFolderCollection();
bafc.GetInfoByParentFolderID(boardID,-1);
int bafcCount=bafc.Count;
DataTable dt = new DataTable("table");
dt.Columns.Add("FolderID",System.Type.GetType("System.String"));
dt.Columns.Add("FolderName",System.Type.GetType("System.String"));
dt.Columns.Add("ParentFolderID",System.Type.GetType("System.String"));
for(int i=0;i<bafcCount;i++)
{
DataRow dr=dt.NewRow();
dr[0]=bafc[i].ID;
dr[1]=bafc[i].FolderName;
dr[2]=bafc[i].ParentFolderID;
dt.Rows.Add(dr);
}
dv=dt.DefaultView;
return dv;
}
#endregion
一點說明:BBSBestArticleFolderCollection對象是個集合類,里面存儲了所有符合條件的數據集合,GetInfoByParentFolderID是其中的一個方法,根據一定條件填充集合類的,此文主要講TreeView構建樹型目錄,此處會在另外的文章中詳述。
b
#region TreeView節點生成方法
private void CreateTree(TreeNodeCollection folderTreeNodeCollection ,int parentID)
{
dv.RowFilter= "ParentFolderID="+parentID;
int tmpParentFolderID=0;
foreach(DataRowView drv in dv)
{
TreeNode tn=new TreeNode();
tn.ID=drv.Row["FolderID"].ToString();
tn.Text=drv.Row["FolderName"].ToString().Trim();
tmpParentFolderID=Int32.Parse(drv.Row["ParentFolderID"].ToString().Trim());
//tn.CheckBox=true;
folderTreeNodeCollection.Add(tn);
CreateTree(folderTreeNodeCollection[folderTreeNodeCollection.Count - 1].Nodes,Int32.Parse(tn.ID));
}
}
一點解釋:遞歸構建樹的各級節點,其中的dv就是上一個方法生成的DataView
c 取得數據的方法有了,生節節點的方法也有了,那么剩下的就是調用了
CreateTree(TreeView1.Nodes,0);
一點解釋:TreeView1是控件ID,這個大家都知道吧,這里的0其實就是表示頂級目錄,從頂級目錄遞歸調用
|