VB.NET Loop through controls in a panel skips controls

后端 未结 2 546
轻奢々
轻奢々 2020-12-22 02:13

Written a quick subroutine in a class to move controls from one Panel to another in VB.NET, which seemed simple enough:

Public Sub Move(ByRef Ol         


        
相关标签:
2条回答
  • 2020-12-22 02:55

    You are changing the collection while using for each to loop through it; that is asking for trouble: once the foreach is started and acquired the enumerator the enumerator is tied to the collection as it was at the start.

    One way to solve this is by first looping and collecting a list of controls to be deleted.

    Then loop the list and remove these controls.

    Another way is to use for which doesn't create an enumerator.

    Note that your code will not work if a control is nested within another control.

    0 讨论(0)
  • 2020-12-22 03:05

    A common solution to this type of problem is to loop backwards over the collection. Then when you remove items it doesn't affect the index of the items you haven't seen yet:

    Public Class Form1
    
        Private Sub Button1_Click(sender As System.Object, e As System.EventArgs) Handles Button1.Click
            MoveControls(Panel1, Panel2)
        End Sub
    
        Public Sub MoveControls(ByVal OldPanel As Panel, ByVal NewPanel As Panel)
            Dim ctlCount As Integer = OldPanel.Controls.Count - 1
            For i As Integer = ctlCount To 0 Step -1
                NewPanel.Controls.Add(OldPanel.Controls(i))
            Next
        End Sub
    
    End Class
    
    0 讨论(0)
提交回复
热议问题