VBA命名参数":="用法和理解
2011-11-05 21:24
615 查看
当调用 Sub 或 Function 过程时,可以根据位置来提供参数,也就是出现在过程定义时的顺序,或者根据名称来提供参数,如此就不用管它的位置。
例如,下面的 Sub 程序接受三个参数:
可以在正确的位置上提供其参数来调用该过程,每个参数之间都以逗点来区隔,如下列的示例所示:
也可以有提供命名参数的方式来调用过程,每个参数之间也是以逗点来间隔。
命名参数是由参数名称接着冒号和一个等号(:=)最后加上参数值所组成。
命名参数在调用具有可选的参数过程时显得特别有用。如果使用命名参数,则不必利用逗号去区分出失去位置的参数。使用命名参数可以很容易的追踪出传递和省略了那些参数。
在过程的定义中,可选的参数前会有一个 Optional 关键字。在过程的定义中也可以指定一个缺省值赋予可选的参数。例如:
当在调用具有可选的参数的过程时,可以选择是否要对可选的参数给于一个值(如果没有的话则会采用缺省值)。如果没有指定缺省值,则此参数可以是属于所指定类型的任何变量。
下列过程包含一个可选的参数,
函数可以决定一个可选的参数是否已经传递给过程。
可以使用命名参数来调用上述程序;如下示例所示:
例如,下面的 Sub 程序接受三个参数:
Sub PassArgs(strName As String, intAge As Integer, dteBirth As Date) Debug.Print strName, intAge, dteBirth End Sub
可以在正确的位置上提供其参数来调用该过程,每个参数之间都以逗点来区隔,如下列的示例所示:
PassArgs "Mary", 29, #2-21-69#
也可以有提供命名参数的方式来调用过程,每个参数之间也是以逗点来间隔。
PassArgs intAge:=29, dteBirth:=#2/21/69#, strName:="Mary"
命名参数是由参数名称接着冒号和一个等号(:=)最后加上参数值所组成。
命名参数在调用具有可选的参数过程时显得特别有用。如果使用命名参数,则不必利用逗号去区分出失去位置的参数。使用命名参数可以很容易的追踪出传递和省略了那些参数。
在过程的定义中,可选的参数前会有一个 Optional 关键字。在过程的定义中也可以指定一个缺省值赋予可选的参数。例如:
Sub OptionalArgs(strState As String, Optional strCountry As String = "USA") . . . End Sub
当在调用具有可选的参数的过程时,可以选择是否要对可选的参数给于一个值(如果没有的话则会采用缺省值)。如果没有指定缺省值,则此参数可以是属于所指定类型的任何变量。
下列过程包含一个可选的参数,
varCountry变量。而 IsMissing
函数可以决定一个可选的参数是否已经传递给过程。
Sub OptionalArgs(strState As String, Optional intRegion As Integer, _ Optional strCountry As String = "USA") If IsMissing(intRegion) And IsMissing(strCountry) Then Debug.Print strState ElseIf IsMissing(strCountry) Then Debug.Print strState, intRegion ElseIf IsMissing(intRegion) Then Debug.Print strState, strCountry Else Debug.Print strState, intRegion, strCountry End If End Sub
可以使用命名参数来调用上述程序;如下示例所示:
OptionalArgs strCountry:="USA", strState:="MD" OptionalArgs strState:= "MD", intRegion:=5
相关文章推荐
- 深入理解C/C++混合编程(关于#ifdef __cplusplus extern "C" {...}的用法)
- 用"堆栈区数据复制"理解Java赋值和参数传递机制的心得
- More Effective C++----(12)理解"抛出一个异常"与"传递一个参数"或"调用一个虚函数"间的差异
- 字符串赋值给字符指针(char *a="hello")的正确理解方式
- extern "C" 用法 (转贴)
- server.CreateObject( "scripting.Dictionary ") 用法
- extern "c"用法解析
- ftp -n -s:"d:\dbbak\up.ftp" 这个命令是什么意思? 参数n s的含意是什么?
- Servlet做删除类似的操作的时候,如果需要传递很多参数简单方法request.getHeader("Referer")
- 从用户角度理解"零拷贝" sendfile(Zero Copy I: User-Mode Perspective)
- 关于 "%*d" 一类的用法总结
- 验证参数传递引发的Java编译错误“No enclosing instance of type XXX is accessible" 及匿名内部类
- extern "C"的用法
- 理解extern "C"
- extern "C"的用法解析
- 三、宏中"#"和"##"的用法
- extern "C"的用法解析
- $_SERVER["REQUEST_URI"],["QUERY_STRING"],["PHP_SELF"] ,["SCRIPT_NAME"]用法
- 系统jsp<%@ include file=""%>头页面常用参数
- struts2文件下载及 <param name="inputName">inputStream</param>的理解