若要从其他过程中调用某个 Sub 过程,请键入该过程的名称并包含任何所需的参数值。 不需要使用 Call 语句,但如果使用了该语句,则必须将任何参数包含在圆括号内。
使用子过程来组织其他过程,使其更易于理解和调试。 In the following example, the Sub procedure Main calls the Sub procedure MultiBeep, passing the value 56 for its argument.
当 MultiBeep 运行后,控件返回到 Main,且 Main 调用 Sub 过程 Message。 
              Message 显示一个消息框,当用户单击“确定”时,控件返回到 Main,且 Main 完成。
Sub Main() 
    MultiBeep 56 
    Message 
End Sub 
 
Sub MultiBeep(numbeeps) 
    For counter = 1 To numbeeps 
        Beep 
    Next counter 
End Sub 
 
Sub Message() 
    MsgBox "Time to take a break!" 
End Sub
注意
有兴趣开发跨多个平台扩展 Office 体验的解决方案吗? 查看新的 Office 外接程序模型。 与VSTO外接程序和解决方案相比,Office外接程序占用的空间较小,您可以使用几乎任何Web编程技术(例如HTML5,JavaScript,CSS3和XML)来构建它们。
使用多个参数调用 Sub 过程
下面的示例演示了使用多个参数调用 Sub 过程的两种方法。 第二次调用它时,需要将参数包含在圆括号内,因为使用了 Call 语句。
Sub Main() 
    HouseCalc 99800, 43100 
    Call HouseCalc(380950, 49500) 
End Sub 
 
Sub HouseCalc(price As Single, wage As Single) 
    If 2.5 * wage <= 0.8 * price Then 
        MsgBox "You cannot afford this house." 
    Else 
        MsgBox "This house is affordable." 
    End If 
End Sub
在调用 Function 过程时使用圆括号
若要使用函数的返回值,请将该函数分配给变量并将参数包含在圆括号内,如以下示例所示。
Answer3 = MsgBox("Are you happy with your salary?", 4, "Question 3") 
如果对函数的返回值不感兴趣,则可以按照调用 Sub 过程的同样方式调用函数。 省略圆括号,列出参数,且不要将函数分配给变量,如以下示例所示。
MsgBox "Task Completed!", 0, "Task Box" 
如果您在上述示例中包含圆括号,则该语句将导致语法错误。
传递命名参数
Sub 或 Function 过程中的语句可使用命名参数将值传递给所调用的过程。 您可以按照任何顺序列出命名参数。 命名参数包含参数的名称后跟一个冒号和一个等号 (:=) 以及分配给该参数的值。
以下示例使用命名参数调用 MsgBox 函数,而不返回任何值。
MsgBox Title:="Task Box", Prompt:="Task Completed!" 
以下示例使用命名参数调用 MsgBox 函数。 将返回值分配给变量。
answer3 = MsgBox(Title:="Question 3", _ 
Prompt:="Are you happy with your salary?", Buttons:=4) 
另请参阅
支持和反馈
有关于 Office VBA 或本文档的疑问或反馈? 请参阅 Office VBA 支持和反馈,获取有关如何接收支持和提供反馈的指南。