MsgBox () - 为什么它对一个参数有效,对多个参数无效?

MsgBox () - why does it work with one parameter but not with multiple parameters?

这是一个非常理论化的问题,我想了解它以扩展我对 VBA 语言的理解,但在 official documentation 中也没有找到任何内容,也没有在此处和其他之前的问题中找到任何内容论坛(也许只是不值得想知道为什么?)。

如果我写:

MsgBox "myPrompt", vbYesNo, "MyTitle"

它会出现一个带有自定义提示、按钮和标题的消息框。 但是,如果我这样写,我会得到一个编译错误(预期为“=”):

MsgBox ("myPrompt", vbYesNo, "MyTitle")

到现在为止,一切都是关于语法的。在第二种情况下,我应该将函数的 return 值存储到一个变量中,所以我非常同意“=”符号是预期的事实。但是,以下行将起作用:

MsgBox("myPrompt")

而且它是无论如何 returning 值 1,我可以简单地看到 运行

a = MsgBox("myPrompt")
MsgBox a

因此,根据我的说法,MsgBox ("myPrompt", vbYesNo, "MyTitle") 在没有赋值的情况下不起作用的原因似乎不再与编译错误所说的预期变量赋值这一事实有关。 请问有人可以向我解释一下吗?

在非常高的层次上,它与编译器如何解释命令有关。

如您所述,这两种方法都有效:

MsgBox "Hello World"
MsgBox ("Hello World")

但这不会(不分配给变量):

MsgBox ("Hello World", vbYesNo, "Title")

这是因为(没有赋值),VB认为只有一个参数值"Hello World", vbYesNo, "Title"。显然,这是不正确的,您会收到一条友好的错误消息。

如果你尝试这个,它会成功的。

MsgBox ("Hello World"), (vbYesNo), ("Title")

因为每个参数都在其自己的一组括号中提供。

在语法上,这与上面的 MsgBox ("Hello World") 语句完全一样。您只是在括号中指定了每个参数,而不是只指定了一个。


编辑

MsgBox ("hello world") 之所以有效,是因为它忽略了方括号,就像它对简单整数赋值所做的那样,例如 x = (2).