幽灵资源网 Design By www.bzswh.com
本tree的数据从sql的表中提取而来,sql表的结构如下:
上面的表中 parentmodeuleID是代表父ID的标志,如果当前节点为根节点,则规定为0.
然后就是如何将上面的单表来组成树状结构.这时我们可以利用IList来加载数据库models来实现,具体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; } } }
然后就是在公共处理页面,将数据库的数据进行组织,形成符合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; }
上面就是利用递归的方式来将数据库的数据组合成合适的json数据,利用到的数据库操作类代码如下:
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数据处理好以后,就可以将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="/UploadFiles/2021-04-02/jquery.js">好了,来看看加载结果吧:
制作过程中需要注意的是:首先,递归必须正确;其次注意js大小写('ChildNodes'被我写成了'childNodes',花费了我一天时间才调整过来 晕哦) 再者就是可以直接调用公共页面的方法,只要在方法前面加上[webmethod]标记即可.
标签:
asp.net树
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。