基于JQuery的asp.net樹實現(xiàn)代碼
本tree的數(shù)據(jù)從sql的表中提取而來,sql表的結(jié)構(gòu)如下:
上面的表中 parentmodeuleID是代表父ID的標志,如果當前節(jié)點為根節(jié)點,則規(guī)定為0.
然后就是如何將上面的單表來組成樹狀結(jié)構(gòu).這時我們可以利用IList來加載數(shù)據(jù)庫models來實現(xiàn),具體Tree類如下:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; namespace RolePermission1 { public class Tree { public int ModuleID { get; set; } public int ParentID { get; set; } public string ModulePath { get; set; } public string ModuleName { get; set; } } }
然后就是在公共處理頁面,將數(shù)據(jù)庫的數(shù)據(jù)進行組織,形成符合jquery tree的json格式,具體代碼如下:
[WebMethod] public static string GetJson() { string json = "["; IList<Tree> t = DB.returnParentTree(); foreach (Tree model in t) { if (model != t[t.Count - 1]) { json += GetJsonByModel(model) + ","; } else { json += GetJsonByModel(model); } } json += "]"; json=json.Replace("'","\""); return json; } public static string GetJsonByModel(Tree t) { string json = ""; bool flag = DB.isHaveChild(t.ModuleID); json = "{" + "'id':'" + t.ModuleID + "'," + "'text':'" + t.ModuleName + "'," + "'value':'" + t.ModuleID + "'," + "'showcheck':true," + "'checkstate':'0'," + "'hasChildren':" + flag.ToString().ToLower() + "," + "'isexpand':false," + "'ChildNodes':"; /*奶奶的,這個地方一定要注意是ChildNodes 而不是childNodes 害得我無語了*/ if (!flag) { json += "null,"; json += "'complete':false}"; } else { json += "["; IList<Tree> list = DB.getChild(t.ModuleID); foreach (Tree tree in list) { if (tree != list[list.Count - 1]) { json += GetJsonByModel(tree) + ","; } else { json += GetJsonByModel(tree); } } json += "],'complete':true}"; } return json; }
上面就是利用遞歸的方式來將數(shù)據(jù)庫的數(shù)據(jù)組合成合適的json數(shù)據(jù),利用到的數(shù)據(jù)庫操作類代碼如下:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Data; using System.Data.SqlClient; namespace RolePermission1 { public class DB { public static readonly string connStr=System.Configuration.ConfigurationManager.AppSettings["connStr"]; public static SqlConnection GetConn() { SqlConnection conn = new SqlConnection(connStr); conn.Open(); return conn; } public static DataTable GetDT(string sql) { DataTable dt = new DataTable(); using (SqlConnection conn = DB.GetConn()) { SqlDataAdapter sda = new SqlDataAdapter(sql, conn); sda.Fill(dt); } return dt; } public static IList<Tree> returnParentTree() { IList<Tree> t = new List<Tree>(); string sql = "select * from Models where [ParentModuleID]=0 order by OrderBy asc"; DataTable dt = GetDT(sql); foreach (DataRow dr in dt.Rows) { Tree tParent = new Tree(); tParent.ModuleID = Int32.Parse(dr["ID"].ToString()); tParent.ModuleName = dr["ModuleName"].ToString(); tParent.ModulePath = dr["MenuPath"].ToString(); tParent.ParentID = Int32.Parse(dr["ParentModuleID"].ToString()); t.Add(tParent); } return t; } public static bool isHaveChild(int id) { bool flag=false; string sql = "select ID from Models where ParentModuleID="+id+""; DataTable dt = GetDT(sql); if (dt.Rows.Count > 0) { flag = true; } return flag; } public static IList<Tree> getChild(int id) { IList<Tree> t = new List<Tree>(); string sql = "select * from Models where ParentModuleID=" + id + ""; DataTable dt = GetDT(sql); foreach (DataRow dr in dt.Rows) { Tree tParent = new Tree(); tParent.ModuleID = Int32.Parse(dr["ID"].ToString()); tParent.ModuleName = dr["ModuleName"].ToString(); tParent.ModulePath = dr["MenuPath"].ToString(); tParent.ParentID = Int32.Parse(dr["ParentModuleID"].ToString()); t.Add(tParent); } return t; } } }
好了,當json數(shù)據(jù)處理好以后,就可以將json打到前臺,交給jquery來處理了,
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="RolePermission1._Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title></title> <script src="jquery.treeview/lib/jquery.js" type="text/javascript"></script> <link href="jquery.treeview/tree.css" rel="stylesheet" type="text/css" /> <script src="jquery.treeview/common.js" type="text/javascript"></script> <script src="jquery.treeview/jquery.tree.js" type="text/javascript"></script> </head> <body> <form id="form1"> <button id="showchecked" runat="server">Get Selected Nodes</button> <div id="showTree" class="filetree"> </div> </form> </body> <script type="text/javascript"> $(document).ready(function() { $.ajax({ type: "post", contentType: "application/json;charset=utf-8", dataType: "json", url: "WebForm1.aspx/GetJson", success: function(data) { var o = { showcheck: true }; o.data = eval(data.d); $("#showTree").treeview(o); } }); }); $("#showchecked").click(function(e) { var s = $("#showTree").getTSVs(); if (s != null) alert(s.join(",")); else alert("NULL"); }); </script> </html>
好了,來看看加載結(jié)果吧:
制作過程中需要注意的是:首先,遞歸必須正確;其次注意js大小寫('ChildNodes'被我寫成了'childNodes',花費了我一天時間才調(diào)整過來 暈哦) 再者就是可以直接調(diào)用公共頁面的方法,只要在方法前面加上[webmethod]標記即可.
相關(guān)文章
Jquery中的offset()和position()深入剖析
jquery 中有兩個獲取元素位置的方法offset()和position(),這兩個方法之間有什么異同?使用的時候應該注意哪些問題?什么時候使用offset(),什么時候又使用position()呢?2009-05-05在Web項目中引入Jquery插件報錯的完美解決方案(圖解)
這篇文章主要介紹了在Web項目中引入Jquery插件報錯的完美解決方案的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-09-09jQuery 調(diào)用WebService 實例講解
以前都是Web程序調(diào)用WebService,.net把WebService封裝的太簡單了,所以之前都是很膚淺的用,都沒有想過更深層的東西,并且只是停留在表面的添加引用和調(diào)用。2016-06-06jQuery ztree實現(xiàn)動態(tài)樹形多選菜單
這篇文章主要介紹了jQuery ztree實現(xiàn)動態(tài)樹形多選菜單,ztree動態(tài)樹形菜單,初始化加載和延遲加載,感興趣的小伙伴們可以參考一下2016-08-08