Asp.net与ExtJs结合,当有三层时就不显示树了,望高手讲解

wantshixiangru168 2011-05-06 09:38:32
/// <summary>
/// 加载树
/// </summary>
/// <returns></returns>
///
StringBuilder jsonSource = null;
public ActionResult doTreeLoad()
{


string FunSql = "SELECT * FROM [FUNCTION]";
DataTable Fun = SQLHelp.GetDataTable(new SQLParams(FunSql, null));
List<Function> FunList = new List<Function>();
for (int i = 0; i < Fun.Rows.Count; i++)
{
Function fc = new Function();
fc.Id = Convert.ToInt32(Fun.Rows[i]["id"]);
fc.Name = Fun.Rows[i]["name"].ToString();
fc.ParentId = Convert.ToInt32(Fun.Rows[i]["parentId"].ToString());
fc.Action = Fun.Rows[i]["action"].ToString();
fc.Remark = Fun.Rows[i]["remark"].ToString();
FunList.Add(fc);
}


string deptStr = "[";
if (FunList.Count > 0)
{
foreach (Function d in FunList)
{

if (d.ParentId == 0)
{
jsonSource = new StringBuilder();
RecursionDept(FunList, d);
deptStr += ModifyStr(jsonSource.ToString());
deptStr += ",";
}
}
deptStr += "]";
}
else
{
deptStr += ",]";
}
deptStr = ModifyStr(deptStr);
Response.Write(deptStr);
Response.End();
Response.Clear();

return null;
}
private void RecursionDept(List<Function> deptList, Function dt)
{
if (HasChild(deptList, dt))
{
jsonSource.Append("{id:" + dt.Id + ",");
jsonSource.Append(@"text:'" + dt.Name + @"',");
jsonSource.Append("children:[");
List<Function> deptSub = GetChild(deptList, dt);
foreach (Function d in deptSub)
{
RecursionDept(deptList, d);
}
jsonSource.Append("]}");
}
else
{
jsonSource.Append("{id:" + dt.Id + ",");
jsonSource.Append(@"text:'" + dt.Name + @"',");
jsonSource.Append("leaf:true},");
}
}
/// <summary>
/// 修改字符串
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
private string ModifyStr(string str)
{
return str.Replace(",]", "]");
}
/// <summary>
/// 判断是否包含字节点
/// </summary>
/// <param name="deptQuery"></param>
/// <param name="dt"></param>
/// <returns></returns>
private bool HasChild(List<Function> deptQuery, Function dt)
{
return GetChild(deptQuery, dt).Count > 0 ? true : false;
}
private List<Function> GetChild(List<Function> deptQuery, Function dt)
{
List<Function> deptSub = new List<Function>();
foreach (Function d in deptQuery)
{
if (d.ParentId == dt.Id)
{
deptSub.Add(d);
}
}

return deptSub;
}
当有两层时显示正确,三层时就不对了,比如A下面有B下面有C,当C下面再有子节点就不显示树了,望高手讲解。
...全文
104 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧