zoukankan      html  css  js  c++  java
  • 使用Linq生成分类Json数据

    public abstract class Category
            {
                
    public static string GetJson()
                {
                    StringBuilder sb 
    = new StringBuilder(500);
                    var pr 
    = new ParentCateRepository();
                    var cr 
    = new ChildCateRepository();
                    var pList 
    = pr.GetAll().Select(a => new { a.ID, a.Name });
                    var cList 
    = cr.GetAll().Select(a => new { a.ID, a.Name, a.ParentID });
                    
    foreach (var a in pList)
                    {
                        sb.Append(
    "{id:'" + a.ID + "',name:'" + a.Name + "',child:[");
                        var c 
    = cList.Where(i=> i.ParentID == a.ID);
                        
    foreach (var b in c)
                        {
                            
    if (b.ParentID == a.ID)
                            {
                                sb.Append(
    "{id:'" + b.ID + "',name:'" + b.Name + "'}");
                            }
                            
    if (b.ID != c.Last().ID)//注意一定要判断字段,不能判断对象因为两种类型是推测所以不同
                            {
                                sb.Append(
    ",");
                            }
                        }
                        sb.Append(
    "]}");
                        
    if (a.ID != pList.Last().ID)
                        {
                            sb.Append(
    ",");
                        }
                    }
                    
    return "["+sb.ToString()+"]";
                }

    生成的数据如下格式:
    [{id:'1',name:'计算机',child:[{id:'1',name:'程序设计'}]},
    {id:'2',name:'语言培训',child:[{id:'2',name:'英语培训'}]}]
  • 相关阅读:
    1月27日 常用函数
    1月25日 JavaScript的DOM操作
    1月25日 JavaScript简介与语法
    1月24日 样式表案例
    5月14日 数字顺序打印并求和
    5月14日 根据班级人数,求平局分,最大值,最小值
    5月14日 九九乘法口诀
    5月14日 打印100以内与7有关的数
    5月14日 函数练习 100以内奇数的和
    5月14日 枚举类型
  • 原文地址:https://www.cnblogs.com/newmin/p/1538789.html
Copyright © 2011-2022 走看看