TreeNodeCollection.IndexOf(TreeNode) メソッド

定義

コレクション内の指定されたツリー ノードのインデックスを返します。

public:
 int IndexOf(System::Windows::Forms::TreeNode ^ node);
public int IndexOf (System.Windows.Forms.TreeNode node);
member this.IndexOf : System.Windows.Forms.TreeNode -> int
Public Function IndexOf (node As TreeNode) As Integer

パラメーター

node
TreeNode

コレクション内で検索する TreeNode

戻り値

ツリー ノード コレクション内に項目が存在する場合は、その項目の 0 から始まるインデックス。それ以外の場合は -1。

次のコード例では、指定した TreeNode が 内 TreeNodeCollectionにあるかどうかを判断し、コレクションを列挙します。 この例では、 という名前の をForm含む TreeNode を持TreeNodeCollectionTreeView が必要myTreeNode2です。

void EnumerateTreeNodes()
{
   TreeNodeCollection^ myNodeCollection = myTreeView->Nodes;

   // Check for a node in the collection.
   if ( myNodeCollection->Contains( myTreeNode2 ) )
   {
      myLabel->Text = myLabel->Text + "Node2 is at index: " + myNodeCollection->IndexOf( myTreeNode2 );
   }

   myLabel->Text = myLabel->Text + "\n\nElements of the TreeNodeCollection:\n";

   // Create an enumerator for the collection.
   IEnumerator^ myEnumerator = myNodeCollection->GetEnumerator();
   while ( myEnumerator->MoveNext() )
   {
      myLabel->Text = myLabel->Text + (dynamic_cast<TreeNode^>(myEnumerator->Current))->Text + "\n";
   }
}
private void EnumerateTreeNodes()
{
   TreeNodeCollection myNodeCollection = myTreeView.Nodes;
   // Check for a node in the collection.
   if (myNodeCollection.Contains(myTreeNode2))
   {
      myLabel.Text += "Node2 is at index: " + myNodeCollection.IndexOf(myTreeNode2);
   }
   myLabel.Text += "\n\nElements of the TreeNodeCollection:\n";

   // Create an enumerator for the collection.
   IEnumerator myEnumerator = myNodeCollection.GetEnumerator();
   while(myEnumerator.MoveNext())
   {
      myLabel.Text += ((TreeNode)myEnumerator.Current).Text +"\n";
   }
}
Private Sub EnumerateTreeNodes()
   Dim myNodeCollection As TreeNodeCollection = myTreeView.Nodes
   ' Check for a node in the collection.
   If myNodeCollection.Contains(myTreeNode2) Then
      myLabel.Text += "Node2 is at index: " + myNodeCollection.IndexOf(myTreeNode2)
   End If
   myLabel.Text += ControlChars.Cr + ControlChars.Cr + _
     "Elements of the TreeNodeCollection:" + ControlChars.Cr
   
   ' Create an enumerator for the collection.
   Dim myEnumerator As IEnumerator = myNodeCollection.GetEnumerator()
   While myEnumerator.MoveNext()
      myLabel.Text += CType(myEnumerator.Current, TreeNode).Text + ControlChars.Cr
   End While
End Sub

注釈

このメソッドにかかる時間はノード コレクションのサイズに比例するため、大規模なコレクションで使用しないようにすることをお勧めします。

このメソッドは、参照の等価性のみをチェックします。 これを使用して、コレクション内の同等の異なるノードのインデックスを取得することはできません。

注意

参照等価要件の 1 つの意味は、 クラスの メソッドをオーバーライドすることによって、TreeNode派生型に対してこのメソッドのTreeNode動作をEqualsカスタマイズできないことです。

適用対象