EasyUI - 操作 Tree 控件

效果:

 

HTML代码:

  • 使用了模板页
复制代码
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">
    <div id="Accordions" class="easyui-accordion">
        <div title="所有用户" data-options="iconCls:'icon-save',selected:true" style ="padding:0 0 0 10px;">
            <ul id="Tree"></ul>
        </div>
        <div title="密码操作" data-options="iconCls:'icon-reload'">
            content2 
        </div>
        <div title="搜索操作" data-options="iconCls:'icon-reload'">
            content3 
        </div>
    </div>
</asp:Content>
复制代码

 

JavaScript代码:

复制代码
$(function () {
    $('#Tree').tree({
        url: "Json/Tree_Node.ashx",
        datatype: JSON,
        lines: true,
        animate: true,
        onClick: function (node) {
            alert(node.text + node.id);
        }
    });
})
复制代码

 

ashx代码(一般处理程序):

复制代码
using System.Data;
using System.Web;
using EasyUI.DAL;
using System.Text;

namespace EasyUI.Json
{
    /// <summary>
    /// Tree_Node 的摘要说明
    /// </summary>
    public class Tree_Node : IHttpHandler
    {
        DataSet ds = new DataSet();
        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            DataTable dt = SelectDT();
            string json = GetTreeJsonByTable(dt, "ID", "CategoryName", "Url", "ParentID", "1000");
            context.Response.Write(json);
            context.Response.End();
        }

        #region 根据DataTable生成EasyUI Tree Json树结构
        StringBuilder result = new StringBuilder();
        StringBuilder sb = new StringBuilder();
        /// <summary>  
        /// 根据DataTable生成EasyUI Tree Json树结构  
        /// </summary>  
        /// <param name="tabel">数据源</param>  
        /// <param name="idCol">ID列</param>  
        /// <param name="txtCol">Text列</param>  
        /// <param name="url">节点Url</param>  
        /// <param name="rela">关系字段</param>  
        /// <param name="pId">父ID</param>  
        private string GetTreeJsonByTable(DataTable tabel, string idCol, string txtCol, string url, string rela, object pId)
        {
            result.Append(sb.ToString());
            sb.Clear();
            if (tabel.Rows.Count > 0)
            {
                sb.Append("[");
                string filer = string.Format("{0}='{1}'", rela, pId);
                DataRow[] rows = tabel.Select(filer);
                if (rows.Length > 0)
                {
                    foreach (DataRow row in rows)
                    {
                        sb.Append("{\"id\":\"" + row[idCol] + "\",\"text\":\"" + row[txtCol] + "\",\"attributes\":\"" + row[url] + "\",\"state\":\"open\"");
                        if (tabel.Select(string.Format("{0}='{1}'", rela, row[idCol])).Length > 0)
                        {
                            sb.Append(",\"children\":");
                            GetTreeJsonByTable(tabel, idCol, txtCol, url, rela, row[idCol]);
                            result.Append(sb.ToString());
                            sb.Clear();
                        }
                        result.Append(sb.ToString());
                        sb.Clear();
                        sb.Append("},");
                    }
                    sb = sb.Remove(sb.Length - 1, 1);
                }
                sb.Append("]");
                result.Append(sb.ToString());
                sb.Clear();
            }
            return result.ToString();
        }
        #endregion

        #region 创建数据
        /// <summary>
        /// 获取数据库中分类数据
        /// </summary>
        /// <returns></returns>
        protected static DataTable SelectDT()
        {
            DataTable dt = new System.Data.DataTable();

            dt = SQLHelper.ExecuteTable("select ID, CategoryName, Url, ParentID from Tb_APCategory", System.Data.CommandType.Text);

            return dt;
        }
        #endregion


        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}
复制代码

 

格式化数据为Json数据(核心代码,从上面截取):

复制代码
#region 根据DataTable生成EasyUI Tree Json树结构
StringBuilder result = new StringBuilder();
StringBuilder sb = new StringBuilder();
/// <summary>  
/// 根据DataTable生成EasyUI Tree Json树结构  
/// </summary>  
/// <param name="tabel">数据源</param>  
/// <param name="idCol">ID列</param>  
/// <param name="txtCol">Text列</param>  
/// <param name="url">节点Url</param>  
/// <param name="rela">关系字段</param>  
/// <param name="pId">父ID</param>  
private string GetTreeJsonByTable(DataTable tabel, string idCol, string txtCol, string url, string rela, object pId)
{
    result.Append(sb.ToString());
    sb.Clear();
    if (tabel.Rows.Count > 0)
    {
        sb.Append("[");
        string filer = string.Format("{0}='{1}'", rela, pId);
        DataRow[] rows = tabel.Select(filer);
        if (rows.Length > 0)
        {
            foreach (DataRow row in rows)
            {
                sb.Append("{\"id\":\"" + row[idCol] + "\",\"text\":\"" + row[txtCol] + "\",\"attributes\":\"" + row[url] + "\",\"state\":\"open\"");
                if (tabel.Select(string.Format("{0}='{1}'", rela, row[idCol])).Length > 0)
                {
                    sb.Append(",\"children\":");
                    GetTreeJsonByTable(tabel, idCol, txtCol, url, rela, row[idCol]);
                    result.Append(sb.ToString());
                    sb.Clear();
                }
                result.Append(sb.ToString());
                sb.Clear();
                sb.Append("},");
            }
            sb = sb.Remove(sb.Length - 1, 1);
        }
        sb.Append("]");
        result.Append(sb.ToString());
        sb.Clear();
    }
    return result.ToString();
}
#endregion
View Code
复制代码

 

完成。

posted on   ultrastrong  阅读(368)  评论(0编辑  收藏  举报

编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· Sdcb Chats 技术博客:数据库 ID 选型的曲折之路 - 从 Guid 到自增 ID,再到
· 语音处理 开源项目 EchoSharp
· 《HelloGitHub》第 106 期
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 使用 Dify + LLM 构建精确任务处理应用
< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

统计

点击右上角即可分享
微信分享提示