office交流網--QQ交流群號

Access培訓群:792054000         Excel免費交流群群:686050929          Outlook交流群:221378704    

Word交流群:218156588             PPT交流群:324131555

使用Controls.Remove CStr(ctr.Name) 刪除動態創建的控件提示齣錯:不能在此上下文中使用此命令

2020-05-04 08:00:00
zstmtony
原創
3507

使用Controls.Remove CStr(ctr.Name) 刪除動態創建的控件提示齣錯:不能在此上下文中使用此命令

運行到此卽齣錯、提示: '運行時錯誤 '444': 無法刪除控件 。不能在此上下文中使用此命令。


先看看微軟官方對Controls.Remove的幫助


Remove 方法                        

從集閤中刪除一箇成員,或者從框架、頁麵或窗體中刪除一箇控件。

語法

object.Remove( collectionindex)

Remove 方法的語法有以下幾箇成分:

成分 説明 
object 必需。一箇有效對象。 
collectionindex 必需。成員在集閤內的位置或索引。可以是數字,也可是字符串。如果該值是數字,則最小值爲零,最大值比集閤中的成員數少一。若該值爲字符串,則必鬚對應有效的成員名。 

説明

此方法隻刪除在運行時間添加的控件。但如果想刪除在設計時間添加的控件,則會齣錯。



VBA動態創建控件使用的是以下的代碼


    Dim ctrLable As Control
    Dim ctrTextBox As Control
    Dim ctrComboBox As Control
    Dim i As Integer
    With Me
        For i = 1 To 10
            '添加標籤控件
            Set ctrLable = .Controls.Add("Forms.Label.1", "lblAuto" & i, True)
            With ctrLable
                .Caption = "第" & i & "箇標籤"
                .Left = 10
                .Top = 35 + (i - 1) * 35
                .Tag = "AutoControl"
                .Visible = True
                'Debug.Print .Name
            End With
            '添加文本框控件
            Set ctrTextBox = .Controls.Add("Forms.TextBox.1", "txtAuto" & i, True)
            With ctrTextBox
                .Left = 10 + 50
                .Top = 35 + (i - 1) * 35
                .Width = 70
                .Height = 20
                .Tag = "AutoControl"
                'Debug.Print .Name
            End With
            '添加組閤框件
            Set ctrComboBox = .Controls.Add("Forms.ComboBox.1", "cboAuto" & i, True)
            With ctrComboBox
                .Left = 10 + 50 + 70
                .Top = 35 + (i - 1) * 35
                .Width = 70
                .Height = 20
                .Tag = "AutoControl"
                '.Visible = false
                .RowSource = "繫統_庫位列錶"
                'Debug.Print .Name
            End With
            
        Next i
        
    End With

    Me.cmdRemoveControl.SetFocus
    Me.cmdCreateControl.Enabled = False


而刪除控件使用的是這樣的代碼


 Dim ctr As Control
 For Each ctr In frmWuLiaoXinXi.Controls
 
    If ctr.Tag & "" = "AutoControl" Then
        Me.Controls.Remove CStr(ctr.Name)  'If Not (TypeOf ctr Is MSForms.TextBox) Then
    End If
 Next



但提示齣錯:不能在此上下文中使用此命令。


後經過不斷嚐試調試,髮現原來是VBA的一箇Bug, 卽如果是使用 Me.Controls.Add("Forms.TextBox.1", "txtAuto" & i, True) 這種方式 在運行狀態動態創建的控件,不會去判斷與已有控件是否重名。

原來是因爲重名的原因,自動創建的控件,卽使與原設計時加的控件重名,繫統也不會報錯。
現修改將我代碼創建的控件使用特殊的前綴後完美解決瞭


另註意 Me.Controls.Remove 隻能刪除代碼在運行狀態動態創建的控件,而不能刪除在設計狀態添加的控件


相關知識


下麵程序是在EXCEL-VBA運行
Sub adf()

  Dim Ctl As Control

  For Each Ctl In Formtest.Controls

    Debug.Print Ctl.Name, TypeName(Ctl)

    Formtest.Controls.Remove Ctl

  Next

End Sub
 
上麵程序是蔘考編寫的

cc = UserForm1.Controls.Count

For TC = 1 To cc - 1

If TypeName(UserForm1.Controls.Item(TC)) = "Image" Then

IC = IC + 1

End If

Next

If IC >= 1 Then

For DC = 1 To IC

UserForm1.Controls.Remove "image" & DC + 1

Next

End If

在網上又找瞭一段程序。目標實現

Sub RemoveBtn()

    Dim ctl As MSForms.Control

    Set vbc = ThisWorkbook.VBProject.VBComponents("UserForm1")

    For Each ctl In vbc.Designer.Controls

        vbc.Designer.Controls.Remove ctl.Name

    Next ctl

End Sub
要註意:Designer.Controls.Remove ctl.Name
運行不成功,有兩箇註意事項:
1是確保VBE當前模式是設計模式。
2如果仍報錯,使用CStr函數,強製返迴控件名字符串,(今天剛剛摸索齣來的技巧,原理暫時不知道)
Designer.Controls.Remove CStr(ctl.Name)

分享