14

我有一个树形视图,其中显示成员可能有重复,而标签不会。例子:

TreeNode node = new TreeNode(itemName);
node.Tag = itemID; //unique ID for the item
treeView1.Nodes.Add(node);

所以,在搜索时,我知道我可以使用 itemName 搜索

treeView1.Nodes.Find(itemName, true);

但是我怎么能通过标签进行搜索呢?treeView1.Nodes.Where 没有定义,所以我没有 linq :(

关于如何按标签搜索的任何建议?:) 谢谢!

4

4 回答 4

20

试试这个:

var result = treeView1.Nodes.OfType<TreeNode>()
                            .FirstOrDefault(node=>node.Tag.Equals(itemID));

注意:因为您说您itemID是唯一的,所以您可以使用FirstOrDefault来搜索唯一的项目。如果没有找到,result将是null.

更新

要搜索所有级别的所有节点,您可以尝试使用一些递归方法,如下所示:

public TreeNode FromID(string itemId, TreeNode rootNode){
   foreach(TreeNode node in rootNode.Nodes){
     if(node.Tag.Equals(itemId)) return node;
     TreeNode next = FromID(itemId, node);
     if(next != null) return next;
   }
   return null;
}
//Usage    
TreeNode itemNode = null;
foreach(TreeNode node in treeView1.Nodes){
  itemNode = FromID(itemId, node);
  if(itemNode != null) break;
}
于 2013-10-07T14:07:30.687 回答
2

Name 属性可能是一个更好的答案。 http://msdn.microsoft.com/en-us/library/system.windows.forms.treenode.name(v=vs.110).aspx

var itemNode = new TreeNode(itemName);
itemNode.Name = itemID.ToString();
treeView1.Nodes.Add(node);

var insertedNode = treeView1.Nodes.Find(itemID.ToString(), true);

我会说这是一种更清洁的处理方式。

于 2014-11-21T16:25:17.540 回答
1
    public TreeNode GetNode(string name, TreeNode rootNode)
    {
        foreach (TreeNode node in rootNode.Nodes)
        {
            if (node.Name.Equals(name)) return node;
            TreeNode next = GetNode(name, node);
            if (next != null) return next;
        }
        return null;
    }

    public TreeNode GetNode(string name)
    {
        TreeNode itemNode = null;
        foreach (TreeNode node in treeViewPermission.Nodes)
        {
            if (node.Name.Equals(name)) return node;
            itemNode = GetNode(name, node);
            if (itemNode != null) break;
        }
        return itemNode;
    }
于 2014-08-10T13:19:23.987 回答
0

通过@Hamix 的标签版本

        public TreeNode GetNode(object tag, TreeNode rootNode)
        {
            foreach (TreeNode node in rootNode.Nodes)
            {
                if (node.Tag.Equals(tag)) return node;

                //recursion
                var next = GetNode(tag, node);
                if (next != null) return next;
            }
            return null;
        }

        public TreeNode GetNode(object tag)
        {
            TreeNode itemNode = null;
            foreach (TreeNode node in _sourceTreeView.Nodes)
            {
                if (node.Tag.Equals(tag)) return node;

                itemNode = GetNode(tag, node);
                if (itemNode != null) break;
            }
            return itemNode;
        }
于 2017-03-08T00:05:48.313 回答