VBA 过程或函数作用域

VBA 中的过程和函数,与变量类似,也具有不同的作用域。根据声明位置和方式,有 3 种作用域:

  1. 模块作用域
  2. 工程作用域
  3. 全局作用域

1.模块作用域

在模块中,使用 Private 关键词声明的过程或函数,具备模块作用域,只能在当前模块中使用。

Private Sub Test()

End Sub

2.工程作用域

在模块中,顶部声明 Option Private Module 修饰语句,并且直接声明或使用 Public 关键词声明的过程或函数,具备工程作用域,在当前工程的所有模块中使用。

Option Private Module

Sub Test1()

End Sub

Public Sub Test2()

End Sub

以上例子中,Test1 过程和 Test2 过程均具备工程作用域。由于直接声明和使用关键词 Public 是等效的,因此可以省略 Public 关键词。

3.全局作用域

在模块中,直接声明或使用 Public 关键词声明的过程或函数,具备全局作用域。例如,

Sub Test1()

End Sub

Public Sub Test2()

End Sub

以上例子中,Test1 过程和 Test2 过程均具备全局作用域,可以在打开的任何一个工作簿中使用。

此外,它们还能直接在工作簿宏列表中执行。

 

转载注明:文章转载自「懒人Excel - lanrenexcel.com
本文标题:VBA 过程或函数作用域
16 评论
最新
最旧 最多投票
内联反馈
查看所有评论
初学者
1 月 前

VBA讲解深入浅出,问题回答耐心细致,学习到很多,非常感谢,希望能继续更新!

浮生若梦
1 月 前

感谢大佬,很实用,从头看到尾。

xiaobaibai
2 月 前

后来讲的就不好了 突然变得很难懂

thank you 大佬
4 月 前

我从头复习一下,搞好基础,等大佬更新后我能跟上节奏,谢谢大佬为我打开新世界的大门

Thanks
5 月 前

看完了,奥里给

785267468
5 月 前

大佬 没有了嘛,大佬还在运营吗

785267468
5 月 前
回复给  懒人Excel

期待大佬,大佬公众号有运营吗

里见羊羊羊
9 月 前

大佬!mark一下,正在学这个

嗑瓜子
10 月 前

作者你好,我想问一下现在全局作用域的概念是不是取消了?我尝试了下全局作用域的变量并不能在另一个工作簿中使用,最多到工程作用域就结束了。

明天的高手
1 年 前

啊哈,来早了,课程没更新完

小峰01
1 年 前

竟然是最后一章了,还没有实例呢

Thanks
5 月 前
回复给  小峰01

对的 确少一个综合开发实例

16
0
希望看到您的想法,请您发表评论x