如何从叶子中获得第二级文本

本文关键字:文本 二级 叶子 | 更新日期: 2023-09-27 18:03:26

如果我的位置是叶子,如何获得第二个父亲

例如:

1 -> 2 -> 3

1 -> 2 -> 3 -> 4>

1 -> 2 -> 3 -> 4 -> 5

如果我在最后一个节点(3 or 4 or 5)

如何获取节点(2)的文本?


    foreach (RadTreeNode node in nodeCollection)
    {
        if (node.Nodes.Count == 0)//leaf
        {
            if (!node.Value.TrimEnd().Contains('#'))
            {
                GroupDetails grp_d = new GroupDetails();
                grp_d.Boss_code = 0;
                grp_d.Boss_name = string.Empty;
                if (node.Value.TrimEnd().Split('_').Count() > 2)
                {
                    grp_d.Boss_code = int.Parse(node.Value.TrimEnd().Split('_')[2]);
                    grp_d.Boss_name = node.Value.TrimEnd().Split('_')[3];
                }
                grp_d.Dep_code = int.Parse(node.Value.TrimEnd().Split('_')[0]);
                grp_d.Dep_name = node.Text.TrimEnd() //Here i want to get the second parent text to concatenate  
                grp_d.Dep_year = int.Parse(node.Value.TrimEnd().Split('_')[1]);
                grp_d.Group_id = res;
                grp_det.Add(grp_d);
            }
        }
    }

如何从叶子中获得第二级文本

while( node.parent != null )
 node = node.parent;
return node.child;

假设你只有一个子节点(即节点(2))

只是建议一种逻辑遍历树的方法。实现取决于您和您的系统设计!

RadTreeNode node_tmp = new RadTreeNode();
      node_tmp = node;
          while (node_tmp.ParentNode != null)
                {
                   p_txt = node_tmp.Text.TrimEnd();
                   node_tmp = node_tmp.ParentNode;
                }