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:'英语培训'}]}]
  • 相关阅读:
    文本设置超过几行显示...
    CSS内置的几个标准的伪类和伪对象
    正则替换URL地址为链接地址
    移动端某些机型touchend事件触发鸡肋
    zepto 扩展prevAll(),nextAll()方法
    火狐下window.event获取undefined问题
    哪些情况下margin-left和padding-left无效?
    兵部-2048
    HTML5 将成为 HTML、XHTML 以及 HTML DOM 的新标准。HTML 的上一个版本诞生于 1999 年。自从那以后,Web 世界已经经历了巨变。HTML5 仍处于完善之中。然而,大部分现代浏览器已经具备了某些 HTML5 支持。
    二分查找
  • 原文地址:https://www.cnblogs.com/newmin/p/1538789.html
Copyright © 2011-2022 走看看