最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

基于JQuery的asp.net树实现代码_jquery

来源:动视网 责编:小采 时间:2020-11-27 20:56:03
文档

基于JQuery的asp.net树实现代码_jquery

基于JQuery的asp.net树实现代码_jquery:本tree的数据从sql的表中提取而来,sql表的结构如下: 上面的表中 parentmodeuleID是代表父ID的标志,如果当前节点为根节点,则规定为0. 然后就是如何将上面的单表来组成树状结构.这时我们可以利用IList来加载数据库models来实现,具体Tree类如下:
推荐度:
导读基于JQuery的asp.net树实现代码_jquery:本tree的数据从sql的表中提取而来,sql表的结构如下: 上面的表中 parentmodeuleID是代表父ID的标志,如果当前节点为根节点,则规定为0. 然后就是如何将上面的单表来组成树状结构.这时我们可以利用IList来加载数据库models来实现,具体Tree类如下:
 本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 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 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 returnParentTree()
 {
 IList t = new List();
 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 getChild(int id)
 {
 IList t = new List();
 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" %>



 
 
 
 
 


 

 

好了,来看看加载结果吧:


制作过程中需要注意的是:首先,递归必须正确;其次注意js大小写('ChildNodes'被我写成了'childNodes',花费了我一天时间才调整过来 晕哦) 再者就是可以直接调用公共页面的方法,只要在方法前面加上[webmethod]标记即可.

文档

基于JQuery的asp.net树实现代码_jquery

基于JQuery的asp.net树实现代码_jquery:本tree的数据从sql的表中提取而来,sql表的结构如下: 上面的表中 parentmodeuleID是代表父ID的标志,如果当前节点为根节点,则规定为0. 然后就是如何将上面的单表来组成树状结构.这时我们可以利用IList来加载数据库models来实现,具体Tree类如下:
推荐度:
标签: 代码 ASP.NET jQuery
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top