VBA将参数传递给userform

时间:2015-06-30 06:44:09

标签: excel-vba arguments userform vba excel

我有一个userform,我希望将范围传递给。我尝试了几种不同的方法,但似乎没有用。

这是子代码:

Option Explicit

Sub Additional_Comments_Normal()
Dim MSG1 As Integer
Dim msg As String
Dim act As Range


On Error GoTo ErrHandler

'Calls userform

MSG1 = MsgBox("Would you like to add comments", vbYesNo, "Add comments")


If MSG1 = vbYes Then

With AddComments
On Error Resume Next
Set act = Application.InputBox(Prompt:="Please choose files you wish to add comments to", Type:=8)

If act Is Nothing Then
Exit Sub
End If
    
    Application.ScreenUpdating = True
    .Show
    
End With

Else
Exit Sub
End If

ErrHandler:

If Err.Number <> 0 Then
 msg = "Error # " & Str(Err.Number) & " was generated by " _
         & Err.Source & Chr(13) & Err.Description
MsgBox msg, , "Error", Err.HelpFile, Err.HelpContext
End If
End Sub

用户形式代码在这里:

Public act As Range

Private Sub CommandButton1_Click()

Dim ctl As Control
Dim rng As Range
Dim MSG2 As Integer
Dim sfile As String


    If act.Column > 1 Then
        MsgBox ("Please choose File name from Column 1")
    Exit Sub
    End If

        If act.Row < 4 Then
            MsgBox ("Please choose a valid file")
        Exit Sub
        End If
         
            If Me.TxtComment.Value = "" Then
                MsgBox "Please add comments", vbExclamation, "Additional Comments"
                Me.TxtComment.SetFocus
            Exit Sub
            End If

            If Me.TxtName.Value = "" Then
                MsgBox "Please add your name", vbExclamation, "Additional Comments"
                Me.TxtName.SetFocus
            Exit Sub
            End If



MSG1 = MsgBox("Add Comments ?", vbYesNo, "Add comments")

If MSG1 = vbNo Then

End If

If MSG1 = vbYes Then

act.Offset(0, 16).Value = act.Offset(0, 16).Text & " " & Me.TxtComment.Value
act.Offset(0, 17).Value = act.Offset(0, 17).Text & " " & Me.TxtName.Value
 
For Each ctl In Me.Controls
If TypeName(ctl) = "TextBox" Then
ctl.Value = ""
End If
Next ctl
      
AddComments.Hide

Application.DisplayAlerts = False
ActiveWorkbook.Save
Application.DisplayAlerts = True

End If

End Sub


Private Sub CommandButton2_Click()

End Sub

Private Sub CommandButton3_Click()
Unload Me
End Sub

Private Sub UserForm_Click()

End Sub

然后我得到一个关于行为未定义变量的错误。

任何人都可以为此更好地了解这个过程吗?

1 个答案:

答案 0 :(得分:1)

您已在代码顶部设置Option Explicit。这意味着需要定义所有变量(这被认为是良好的编程实践)。因此,您有两种方法可以解决此问题:

(1)从代码中删除行Option Explicit

(2)使用Dim命令定义所有变量。在这种情况下,您必须将Dim act as Range添加到表单上的子CommandButton1_Click

如果你想将一个变量传递给另一个sub,那么你可以这样做,用这个变量调用那个sub:

Call Additional_Comments_Normal(act)

并且子标题需要像这样改变:

Sub Additional_Comments_Normal(ByVal act as Range)

'(your code)'

End Sub

如果“将变量传递给另一个子”太麻烦了,那么您也可以将文件保存在文件中的某个位置,如下所示:

SomeHiddenSheet.Range("A1").Value2 = act

在另一个子组中,您可以再次发起行动:

act = SomeHiddenSheet.Range("A1").Value2